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I. INTRODUCTION 


A large number of World Wide Web (WWW) applications can be interpreted 
as providing access to a collection of digital resources such as information (e.g., The 
Library of Congress |Ref. 1]), or software code (e.g., The Java Repository [Ref. 2]), or 
mathematical decision models (e.g., DecisionNet [Ref. 3]). Collections or repositories, 
in the classical library science approach, are subject to operations such as classification 
and indexing, and search and retrieval. However, these operations are only weakly, 
if at all, supported in most Web-based repositories, leading to difficulties in locating 
suitable objects from large collections. For example, a search conducted using general 
search engines such as Excite [Ref. 4] or Lycos [Ref. 5] results in thousands of “hits” 
only a few of which may actually be relevant. 

This thesis describes a system for classifying, registering, searching, and re- 
trieving objects in a Web-based digital library, in a way that these functions can be 
accessed by users via their Web browsers. This work is done in the specific context 
of DecisionNet [Ref. 6], a digital library of decision technologies. However, in its 
architecture and design as well as in its implementation, the system is general enough 
to be immediately useful for classification and search in other repositories. Since the 
classification of objects in DecisionNet is done with multiple attributes, each of which 
has several levels, a Web-based user interface for access to classification and search 
functions poses significant challenges. Hence, much of the system and this thesis is fo- 
cused on the development of a general, Web-based, user interface for a multi-variable, 


multi-dimensional classification of a repository of objects. 


A. THE DECISIONNET CONCEPT 


DecisionNet is a framework for brokering the use of decision support technolo- 


gies. Earley [Ref. 7] described DecisionNet in the following terms: 


The main premise of DecisionNet is that consumers should be able to utilize 
decision support technologies as services over the World Wide Web (WWW), 
instead of purchasing them as stand-alone products. By providing decision 
support technologies over the WWW (either for free of for a nominal usage 
fee), users would be able to tap into the power of such technologies without 
the normally prohibitive costs involved with purchasing or downloading and 
installing a specific product. The DecisionNet prototype serves as an interface 
between consumers and providers of decision support software, so that interac- 
tions with multiple technologies may take place at one convenient location. In 
this sense, DecisionNet performs the role of an agent, facilitating transactions 
between consumers and providers of decision support technologies. 


With that as a foundation we will explore the genesis of this thesis. 


B. IMPROVING DECISIONNET 


The need for an improved search engine in DecisionNet was first identified 
by Rogers. [Ref. 8] It stated, ” Further research is needed on the second part, to 
develop intelligent search and retrieval algorithms.” The search and retrieval problem 


continued and was further identified by Earley. [Ref. 7] It stated: 


The indexed search script developed in this thesis assumes that the consumer 
is looking for exact matches to his query. However, there may be some tech- 
nologies that are closely related to a consumer’s query without being an exact 
match. The taxonomy for indexing technologies is already in place and func- 
tional. (Rogers, 1996) A method for assigning ’scores’ based on a consumer’s 
request would prove to be beneficial. 


As the size of an object library grows, so will the diversity of the objects in 
that library. The taxonomy needed to accurately classify these diverse objects will 
also grow. A taxonomy is a shared set of terms that are relevant to the domain of 
knowledge that the objects are a part of. As the taxonomy and number of search 
criteria grow, the likelihood of finding exact matches drops very quickly. This is true 
of DecisionNet, which contains relatively few objects. These observations provide the 


basis for this thesis. 


C. PROBLEM DEFINITION 


Information retrieval on the WWW is both an art and a science. Keyword 
based searches may retrieve nothing or several million hits. The art is knowing what to 
search for. WWW search engines, even the ” advanced” search engines, are notoriously 
inaccurate (commit both Type 1 errors and plenty of Type 2 errors). A Type 1 error 
occurs when a relevant result is ignored. A Type 2 error occurs when an irrelevant 
result is returned. A search for Apple Computers returns 58,312 hits or possible 
items of interest. Of those, approximately 320 are closely tied to the corporation in 
question. The remaining sites have little to no relevance to Apple Computers Inc. 
This example uses WWW sites, but the same idea applies in general to any ’object’. 
The challenge is to rank various objects giving the user the most relevant results. 
What is a good measure of relevance? Is number of occurrences of a word or the 
semantic distance between desired and available terms appropriate? 


Reasons for the inaccuracy of searches include: 


e The lack of common semantics between multiple sites, providers of objects, 
and users of objects 


e Inexact classification, if any, of objects using the semantics that do exist 


e Lack of reliable methods to compute relevance of objects that only satisfy some 
of the attributes that a user is looking for 


The purpose of taxonomies is to develop a shared understanding of lists of terms, 
and relationships between these terms, encountered in work in some domain. Once 
there is a taxonomy, the search engine can make use of the shared vocabulary as well 
as exploit the relationships between terms in order to create meaningful relevance 
scores. A taxonomy may be multi-dimensional, which means that each object must 
be described using more than one collections of class terms. 

A taxonomy-based organization and search system would facilitate working 
with taxonomies, including creating and maintaining the classification terms, classi- 


fying objects, and conducting searches. It would include a taxonomy browser, taxon- 


omy editor, taxonomy-based search engine, an editor for search criteria specification, 
search algorithm, search algorithm parameters editor, and a results visualizer. 

However, taxonomies—and the accompanying relationships—can be fairly com- 
plex. For example, in multi-level taxonomies, two terms may be related but it may 
require several steps to make the deduction that they are. In multi-dimensional tax- 
onomies, multiple independent collections of terms may be required to classify the 
objects, each collection comprising a taxonomy. Developing the various components 
of a taxonomic system gets more complex when the taxonomy is dynamic, multi- 
variable, and multi-dimensional; it becomes particularly challenging in the context of 
developing Web-based taxonomic systems. 

In this thesis, we give a formal logic-based specification of a taxonomy-based 
organization and search service. We focus on a particular kind of taxonomic system, 
where the taxonomy is restricted to a hierarchical arrangement of terms (with single- 
inheritance) but one which may consist of multiple independent taxonomies. The 
multi-taxonomy aspect of such systems complicates the design of its different compo- 
nents, including the browser, editor and the search and retrieval methods. Multiple 
inheritance would make things further complex, but we think our approach would 
generalize and scale up to that scenario as well. 

Our interest in this area grew out of work on designing DecisionNet, a digital 
library of decision technologies. DecisionNet, as described in Section A, is currently 
implemented through common gateway interface (CGI) scripts. This implementation 
limits it to a single taxonometric dimension. The introduction of Java applets allows 


users to view and utilize the entire four level taxonomy.[Ref. 8] 


D. OUTLINE FOR REMAINDER OF THESIS 
Chapter II discusses the taxonomy and defines relationships within it. Chap- 
ter III explores the challenges of searching and retrieving multi-variable, multi- 


dimensional objects. Chapter IV provides the analysis and design of the goal ar- 


chitecture. Chapter V represents the actual implementation and the rationale for 
deviations from the goal architecture. Chapter VI is a tour of the system. Finally, 
Chapter VII identifies the difficulties and challenges that were overcome and those 


that remain. 


-— SS aa 





If. TAXONOMY 


A. TAXONOMY: FORMAL SPECIFICATION 

Definition 1 (Taxonomy) A tazonomy is a collectionT of class terms used in clas- 
sifying or describing a library of objects A in some domain. The classification is 
achieved via instances w(T, A) of mapping relationships UV. Additionally, there may 
be instances w(T, IT’) of structural relationships 2 involving the elements of [, and a 
collection of logical axioms ® constraining these relationships. To be precise, each 
element in V is a relationship that maps elements of A onto elements of [, and each 
element in (2) 1s relationship from the set I’ onto itself. 


Formally, we write a taronomy scheme as a tuple 


<0,0,U > (Tiel) 


and a taxonomy instance as a tuple 


<T,w(T,),®, A, ¥(F, A) > GD) 


In this thesis, as mentioned above, our interest is in a special kind of taxonomic 
system. This system is defined by specifying the structure of 9, ® and WV. For the 
purpose of specifying the denotational semantics of the relationships, let A denote the 
universe of discourse (i.e., each object in A maps to an element of A) corresponding 
to the object collection A that needs to be classified and searched. Further, for any 
class term 7 (€ I’), let A, denote the objects (subset of A) belonging to class 4. 


1. Relationships 
We include the following relationships in our taxonomic system. 


a. Q) 


Taxonomy specification involves two relationships: refines and syn. 


e refines: a binary relationship of the form 7; refines yo, where 7, yo € I’. The 
informal interpretation is that all objects in the class 7, also belong to class 
2. Formally, we get 


V1,72 (MN refines 72) — (A,, € A,,) (II.3) 


e syn: a binary relationship of the form syn(y, 72), where y,,7 € [. The 
informal interpretation is that classes 7, and 72 are synonyms. Formally, the — 
semantics are given as: 


(syn(71, ¥2)) > (Ay, = A,,) (11.4) 


Sometimes, synonyms may be used to force a hierarchical representation for a 
collection of terms and relationships that would otherwise require a network 
(multiple parents allowed). This is achieved by making a copy—synonym—of 
an object at multiple branches in the taxonomy tree. 


In adaition, we make use of a relationship isA (of the form + isA 2) 
which is derived from the relationship refines, except that isA is transitive (a complete 
definition is given via axioms II.8 and II.9). This relationship, strictly, is not required, 
but is included as syntactic sugar and for ease of exposition. 

Finally, note that we can define a relationship parent which is the 
inverse of the isA (or child) relationship, and relationships ancestor and descen- 
dant that are transitive relationships based on the parent and child relationships, 
respectively. 


b. WV 


Object classification involves just one relationship ins-of. 


e ins-of: a binary relationship of the form A ins-of y, where AX € A andyeé Tl. 
The interpretation is that object \ in the domain belongs to the class 7 in the 
taxonomy. Formally, we say 


(A ins-of y) — (A € A,) (11.5) 


As above, we also allow a binary relationship sib (of the form sib(,), A), 
derived from the relationship ins-of, to indicate that A; and A> are siblings (have the 
same parent); Axiom II.14 further clarifies the meaning of this relationship. This 


relationship, strictly, is also not required, but is included for clarity. 


2. Axioms, ® 


The formal semantics of, and integrity constraints on, the relationships stated 


above can be stated clearly via the following axioms. 


refines: subclass hierarchy, single-parent hierarchy All objects that are 
an instance of a certain class are also instances of its parent class. Second, 
each term in I can be a refinement of at most one (parent) term. The root 
term has no parent. 


((X ins-of y,) A (71 refines 72)) — (A ins-of 72) (11.6) 
(11 refines 72) A (7: refines y3)) — (72 = 7s) (IL-7) 


isA: refines, transitive 


(7, refines y2) — (7 isA 72) (11.8) 
((y, isA Yo) A (Yo isA y3)) — (MN isA 73) (11.9) 


In terms of the universe of discourse, 


("1 isA y2) (A, C A,,) (II. 10) 


synonym: equivalence relation 


syn(71, 71) (eine 
syn(71,72) — syn(72,7) (II.12) 
(syn(j1, Y2) A syn(y2,73)) — syn(71, 73) (11.13) 
sibling 
((\; ins-of -y) A (Ag ins-of y)) © sib(\;, A2) (11.14) 


3.  Multi-Dimensional Taxonomic System 

A multi-dimensional taxonomic classification system is one in which a collec- 
tion of objects A must be classified along more than one dimension, and where there is 
an independent taxonomy on each dimension. In an n-dimensional taxonomic system, 
let us denote the collection of terms in the taxonomies by [!... ['”. If we assume 
that all dimensions are governed by the same relationship schemes (Q, ®) and axioms 


(Y), then a multi-dimensional taxonomic scheme can be written as the tuple 


<0,8,U> (II.15) 


and a taxonomy instance as a tuple 


< (I,...,T*) (@ oP’), ,@@", I")) Opel) er. bwA) See i.16) 


which may, alternately, be written as a collection of tuples: 


<a Po Ae ee =< Te. em, Ae de emi 


B. TAXONOMY DEVELOPMENT AND OBJECT CLAS- 
SIFICATION 


1. Taxonomy Development 


For a single taxonomy, this means specifying 


e elements of I 


e instances of the relationships in 2, (i.e., instances of refines and syn). 


For example, consider the “problem type” taxonomy tree from the GAMS 
system, [Ref. 9] displayed in Figure 1. Elements of I are all the terms appearing in 
the list. The subclass relationships are represented using the refines relationship, e.g. 


(using the shorthand codes from the taxonomy), 


refines(G1,G) 


refines (G2,G) 
refines (G2a,G2) 
refines (G2b,G2) 
refines (G2b,G2) 
refines(G2c1,G2c) 
refines «a2c2, Ge) 
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([F] Solution of nonlinear equations 
[G] Optimization (search also classes K, L8) 
[Gi] Unconstrained 
[G2] Constrained 
([G2a] Linear programming 
([G2b] Transportation and assignments problem 
([G2c] Integer programming 
[G2c1] Zero/one 
[G2c2] Covering and packing problems 
[G2c3] Knapsack problems 
([G2c4] Matching problems 
([G2c5] Routing, scheduling, location problems 
[G2c6] Pure integer programming 
[G2c7] Mixed integer programming 
[G2d] Network (for network reliability search class M) 
[G2e] Quadratic programming 
[G2f] Geometric programming 
[G2g] Dynamic programming 
[G2h] General nonlinear programming 
[G2i] Global solution to nonconvex problems 
(G3) Optimal control 
[G4] Service routine 
(H] Differentiation, integration 
(I] Differential and integral equations 
[J] Integral transforms 
([K] Approximation (search also class L8) 


Figure 1. Fragment of “problem type” taxonomy from GAMS system 


For an n-dimensional taxonomy, this process must be repeated for each of the 


n dimensions. 


Note also that there is an obvious database implementation of a taxonomy in 


terms of these two relations. 


2. Object Classification 
Classification of objects 4 € A involves specifying instances of the relationships 


in W, i.e., one instance of the ins-of relationship for each A € A. 


Ja 


Modules for class G2cl 
Package NAG at GRANTA 


e HO2BBE Solves zero-one, general, mixed, or all (pure) integer programming 
problems using ... 


e HO2BBF Solves zero-one, general, mixed, or all (pure) integer programming 
problems using ... 


Figure 2. Fragment of object classification in GAMS taxonomy 


which would be represented as 


ins-of (G2c1,HO2BBE) 
ins-of (G2c1,HO2BBF) 
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IIT. SEARCH AND RETRIEVAL IN A 
TAXONOMIC SYSTEM 


Assume that an object receives a score of 1 if it matches exactly the search 
criteria specified by the user, and a score of 0 when it has no relevance to the user’s 


requirements. 


A. SEARCH CRITERIA SPECIFICATION 


Let « denote the criteria for searching and determining relevance of objects in 
a taxonomy. For a single-dimensional taxonomy, « simply specifies a class ¥ € T. If 


we denote the dimension by 0, then & may be written as 


§=F (III.1) 


which specifies a search for objects that belong to, or otherwise are relevant 
to, class 7. For a multi-dimensional taxonomy with dimensions 06),...,6,, we write 


the criteria «; for dimension 2 as 


(6: = Ji) (111.2) 


whereas the complete search criteria « is specified as 


(0) = 1) A... A (On = In) (III.3) 


B. RELEVANCE FUNCTION 

We can state, without loss of generality, that if an object perfectly matches a 
search criteria K, it receives a score of 1, and that if it matches perfectly the criteria x; 
for dimension 7 then it receives a score of 1 on that dimension. Given a search criteria, 


the overall relevance score 9 of an object is computed as a weighted function—whose 
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values fall in the [0,1] interval—of its relevance scores on each dimension. The general 


form of such a function can be given as: 


O(A|K) = wi i(A|K;) (III.4) 
where @; is the score on Pr aanauaet 2 and where the weights w; sum to 1. Note 

that instead of 5> one could use some other aggregation operator. 
To complete the definition of a relevance function, we need to define how to 
compute the relevance score on each dimension. Many such functions are possible, 
and in general we can assume that they work by measuring how the object is related 


to the desired class, and how close the relation is. 


e Relevance: In our taxonomic system, an object that does not match the search 
criteria exactly (i-e., it is not an instance of the desired class) may still be 
relevant because it belongs to a parent, child or sibling class of the ideal class. 
We stated these relationships, all of which draw from the base relation refines, 
in Chapter IT Section A. 


Of course, being a parent may not be of equal relevance as being a child or a 
sibling. In each case, the relevance score must be suitably degraded. Therefore, 
we define separate (0,1) parameters o,, o, and a; as the degradation multipliers 
for objects belonging to the parent, child and sibling, classes of the desired 
class. 


e Distance: Objects that belong to a parent, child or sibling class of the ideal 
class are, obviously, only one level from the ideal. More generally, objects that 
belong to ancestor and descendant classes (and we do not consider cousins) 
are m levels removed from the ideal class, and their relevance should decrease 
as the distance increases. 


Here, we define a partial function ™m,es to compute the levels between two 
classes. (Note that the function is undefined when the two classes are not on 
the same root path.) 


y refines yo — Mrez(71,72) = 1 (III.5) 
Mref(%,7) = O (111.6) 

Mref (V1, Y2) _ itera ey) (II1.7) 

see (V1) etree (nia) te (3570) (III.8) 
(III.9) 
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The relevance score 6; on dimension 72, given search class 7;, of an object A 


which belongs to class 7¥ is 


if Mres (7, Vi 2 O 
6;(A|K;) = os teiaaahc =p (III. 10) 
ao, if y isa sibling of 4; 
| 0 otherwise 
Recall that the overall relevance score 6 is computed by combining the scores 
d; as in Equation III.4. 
It may now be obvious that the relevance function 6 resembles a probability 
function—the relevance score 6(\|k) can be interpreted as the probability that an 


object A would be relevant to a user who specified the search criteria k. The function 


can easily be customized by users via the following input parameters: 


e Weights w),...,W, for dimensions 


e Degradation multipliers o,.,0p, and a; 


C. SEARCH ALGORITHM: EFFICIENCY AND COM- 
PLEXITY 


The objective of a search algorithm is to find the z most relevant objects in 
an object library, based on a variety of factors listed below, but where z itself is a 
parameter that cannot be specified in advance with any degree of credibility. The 
algorithm must employ methods to prune and terminate the search (worst case is to 
compute a relevance score for every object in the library, but this is not desirable). 
For example, one may search only up to two levels from the desired class. Or, perhaps, 
dynamically determine the search depth in a dimension as some function of the weight 
of that dimension. These search strategies may be specified as meta-rules in the search 


system, and can make the search much more efficient. 
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D. COMPONENTS OF A TAXONOMY-BASED OBJECT 
CLASSIFICATION AND RETRIEVAL SYSTEM 


We have developed the mathematical and taxonometric framework to solve this 
problem. We will now translate that framework into components that are required to 
perform the various functions. The following list describes the components in broad 


terms. Chapter V will map these components to those developed for this thesis. 


e Taxonomy Browser 


This module allows users to navigate a single or multi-dimensional taxonomy. 
A hierarchical taxonomy can be displayed in many ways, including as an in- 
dented list (the approach employed in GAMS), as a tree or hierarchy, and as 
a cascading list (the approach employed in this thesis). 


e Object Classification Editor 


This module allows users (object providers) to classify newly entered objects, 
or to change classification of existing objects, in terms of the classes in the tax- 
onomy. This usually requires a taxonomy browser to allow users to determine 
which classes in the taxonomy are most suitable for the object to be classified. 


e Search Criteria Editor 


This module allows users (consumers) to specify the search criteria to be used 
in retrieving objects from the library. The criteria are limited to terms con- 
tained in the taxonomy. 


e Search Algorithm 


This algorithm retrieves a list of objects from the library, based on the rele- 
vance scores of objects, computed on the basis of the search criteria specified 
by the user and the relationships in the taxonomy and object databases. For 
objects that do not exactly meet the user’s criteria, the relevance is computed 
based on the degradation parameters for inexact matches. 


e Search Parameters Editor 


This module lets the users specify the weights for the different attributes, as 
well as the values of the degradation parameters used in the relevance function 
in the search algorithm. 


e Search Results Visualizer 


This module displays the results of the search function. Options include dif- 
ferent ways of sorting the results, reeomputing relevance scores if user changes 
some of the parameter values, and displaying the results in different ways. 
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iy. ANALYSIS AND DESIGN 


Recall that the objectives of this thesis are the classification, registration, 
search, and retrieval of multi-variable digital objects. The design shown here achieves 
these goals within the limitations that will be discussed. The assumptions and deci- 


sions that were made during the analysis and design process are discussed here. 


A. ASSUMPTIONS 
A number of technologies are available today to develop a WWW applica- 


tion. Performance of the system depends both on the development technology and 
the technical capabilities of the user (e.g., user’s Web browser and type of Internet 
connection). In developing our system, we made certain assumptions about user ca- 
pabilities before selecting the development technologies. The user is assumed to have 
a Java capable Web browser. In most cases this translates to either Internet Explorer 
or Netscape Navigator (versions 2.X and higher). To access the system the user must 
have some knowledge of the WWW. Prior knowledge of Decision Support Systems 
(DSS) is not required. Access is assumed to be through a 28.8 kb/s modem. 


B. DESIGN CRITERIA 


The design criteria are also goals set for this system. The design criteria are 


shown in the following list. 


e Platform Independence 
e Usability 


e Generalization 


Platform independence means that anyone with a Java capable Web browser 
and Internet access will be able to use this system. The hardware, operating system, 


and Web browser are irrelevant. The Java Virtual Machine (JVM) will handle the 
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differences that have made platform independence impossible in the past. Java, with 
its promise of ” Write Once, Run Anywhere”, is the primary programming language. 
(Ref. 10] The system must be accessible to the average user to satisfy the second 
design criteria. 

Usability, as we use it in this thesis, is defined by the user. The graphical 
user interface (GUI) is intuitive and easy to navigate. The system runs over the 
WWW and does not require any new software to be installed on the client machine. 
Efficiency and speed are acceptable to the average user. This factors must be met or 
people will not use the system. 

Generalization allows the system to display any taxonomy that conforms to 
the size and depth limits. The DecisionNet project calls for a five variable, four 
dimension system. All five variables do not extend to four dimensions in this case. 
New taxonomies may have fewer than five variables and fewer than four dimensions. 
The only limit imposed is the upper bound. Beyond the taxonomy, generalization 
also means that new CGI scripts can be called to achieve the registration and search 
functions without altering the Java applets. Input parameters to the applets allow 


this flexibility. The input parameters are discussed in Appendix C. 


C. FUNCTIONALITY 


There are four main functions performed by the system. They are: 


Classification 


Registration 
e Search 


Retrieval 


Classification of objects is a function performed by producers of decision tech- 
nologies. Classification allows the producer to define his technology within the De- 


cisionNet taxonomy. The accurate placement within the taxonomy is essential prior 
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to registration. The applet’s multi-level display capability allows the use of the full 
taxonomy that was not previously possible. The taxonomy allows the classification 
of an object (DSS in this case) in each of five attribute areas. Each attribute may 
extend as many as four levels down in a hierarchical structure that is defined by par- 
ent /child relationships. The registration function takes the results of the classification 
and enters them in the technology object database. 

The current system is capable of search by one variable only, with binary or 
yes/no results. An algorithm to examine all of the possible relationships is needed 
to produce a relevancy score. This would give a relative distance from the search 
criteria for objects of possible value to the user. A user also requires the ability to 
define a weight for each attribute as well as degradation multipliers for relationships 
other than an exact match. These relationships are defined in Chapter II Section A. 

The last functional area is retrieval. This could also have been labeled display. 


The search results must be returned in a format that is easily interpreted and usable. 


D. CLIENT VS. SERVER 


In a client /server environment there are decisions to be made about where best 
to locate components of a system. Each node has pros and cons that influence design 
decisions. A node, in this context, is simply a computer. A node can be a client, a 
server, or both. With client machines getting more capability every day there is a 
tendency to push components out to the client whenever possible. 

This client centric approach works well when bandwidth is not a concern. The 
client/server options must be consistent with the future expansion of DecisionNet. 
The system must be scaleable and robust. The assumption that users access Deci- 
sionNet through a modem requires that download time be a consideration. Server 
load and capabilities are another driving factor. The main DecisionNet server is a 
Pentium (90 MHz) with 24 MB of random access memory (RAM). The current hard- 


ware is adequate, but it can quickly be bogged down with several simultaneous users. 


ig 


Option A (Current system) - Server Intensive 


Dnet HTML / CGI Scripts 
DBI & DB2 
Search Algorithm User 
(server) (client) 


DB1=Taxonomy DB 
DB2-Technology Object DB 


Write to DB for Registration 


Considerations: 

-server intensive 

-low user interactivity 

-no browsing of the taxonomy 
-no relevancy scores of searches 





Figure 3. Time Sequence Diagram - Option A 


With these factors in mind we examine three options. 


1. Option A - Server Intensive 

The first option is a description of many current CGI systems. The process- 
ing load is almost entirely on the server node. The client browser does little more 
than display hypertext mark-up language (HTML) pages. The server dynamically 
generates HTML pages through CGI scripts. Figure 3 describes the interaction and 
the location of various components. There is no significant processing on the client 
node. The CGI scripts generate content dynamically, but it is static once it reaches 


the client. This produces very low interactivity. 


2. Option B - Client Intensive 
In direct contrast to Option A, Option B is almost entirely on the client node. 
‘T’he server is little more than a file and database server. In a networked environment 


with 10 MB/s - 1 GB/s data transfer rates this option would be a good one. With 
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Option B - Client Intensive 


Dnet User 
(server) (client) 


DB1=Taxonomy DB 


Applet, Search Algorithm, DB2=Technology Object DB 


DB1, DB2 


Write to DB for Registration 


Considerations: 

-very high transmission time 
-run time would be slow 
-possible RAM limitations with 
Java Applet security features 





Figure 4. Time Sequence Diagram - Option B 


users accessing the system with 28.8 kb/s modems it will prove to be unusable due 
to the long transmission times. Figure 4 describes the interaction and the location of 
various components. 

As both the taxonomy and object databases grow, the situation will get worse. 
The security features of Java applets could become a limiting factor. By design, 
applets are downloaded, stored, and run entirely in the client’s RAM. A security 
feature of applets is their inability to read or write from any drive except the server 
from which they were launched. With large databases and applet code, a client may 
not be able use the system due to memory limitations. The ability to access a client’s 


local drive is being considered for a future Java release. 


3. Option C - Goal Architecture 
Option C combines the benefits of Options A and B. The components whose 


functions do not rely on repeated server communications, and can be economically 


a 


Dnet User Taxonomy Search Technology 
DB(DB1) Algorithm DB (DB2) 
(server) (client) (client) (server) (server) 
Request 


Applet & DB] Tax Variable 


Write to DB 


(registration) eria (RMI ae 
sts ey 
Results for | Displa Results 


(appplet or HTML) 


ption C (Goal architecture - Client & Server 


e 


Figure 5. Time Sequence Diagram - Option C 


transmitted, are located on the client node. Functions that fail either of those criteria 
are located on the server node. This approach is a three tiered client/server architec- 
ture. [Ref. 11] The taxonomy database and the applet code reside on one server. The 
technology object database and search algorithm reside on a second server. Commu- 
nication is limited once the applet is loaded onto the client. Figure 5 describes the 
interaction and the location of various components. 

There are several factors that make the three tiered approach attractive. The 
taxonomy database is closely tied to the applet. It is also relatively small and stable. 
It is much more efficient to send the taxonomy with the applet that will use it than 
to have repeated calls back to the server. This approach allows repeated browsing 
with no additional overhead. 

The search algorithm is closely tied to the technology object database. This 
database could become quite large resulting in transmission delays if it were sent to 


the client. The search algorithm could also be a bottle-neck. The search algorithm 
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Figure 6. Goal Architecture 





is computationally intensive and makes repeated queries to several databases. These 
facts, combined with the transmission time, could make the search performance un- 


acceptable. 


E. THE ALL-JAVA SOLUTION 

Sun’s Java Developer’s Kit (JDK) 1.1.2 supports a three tiered client / server 
architecture. The additions of Remote Method Invocation (RMI) and Java DataBase 
Connectivity (JDBC) make the three tiered design possible. The applet security 
restrictions are enforced by only allowing the applet to communicate with the server 
that launches it. The applet server makes calls to the database server on the applet’s 
behalf. The applet is limited in what it can do because the methods available to it 
are defined in the interface running on the applet server. The applet server acts as 
an intermediary between the applet and the object database server. 


This design meets the technical goals that we established and took advantage of 


23 


the strengths of both client and server nodes. However, the goal architecture currently 
fails the test of usability. The only browser that currently supports JDK 1.1.2 is 
Sun’s HotJava browser. Netscape Communicator and Microsoft Internet Explorer 
dominate the market of Web browsers. Neither one has fully implemented the latest 
Java release and neither currently supports this design. Chapter V describes the 
actual implementation and discusses areas where it differs from the ideal technical 


solution shown here. 
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V. IMPLEMENTATION 


As discussed in Chapter IV, the goal of an all-Java, three tiered client server 
solution is not currently feasible. Without Web browser support, the design would not 
meet user needs, and thus fail the second design criteria of usability. The decision was 
made to modify the design to include a CGI based search algorithm on the database 
server. A suitable existing algorithm could not be located. The existing DecisionNet 
system consists of CGI scripts written in Object Pascal using the Delphi development 
tool. To maintain consistency with the existing system the search engine is written 
in Delphi. 

Figure 7 illustrates the component location and system interaction. The only 
non-Java component is the search algorithm which will be discussed further in Sec- 


tion C. 


Java Integration with existing Dnet Components 
1 - Object Library Browser (future project-java applet) 
2 - Taxonomy Browser (java applet) 
3 - Object Classification Editor (utilizes #2) 
4- Registration Object (existing Delphi CGI script-uses #3) 
5 - Search Criteria Editor (utilizes #2) 
6 - Search Algorithm (delphi CGI script) 
7 - Search Parameters Editor (java applet) es 


8 - Search Results Visualizer (java applet) 








Existing 
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Da é* 
so 






Object Library Taxonomy DB 


Figure 7. System Integration 
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A. TAXONOMY DATA FILES 

The original design called for the taxonomy to be read dynamically from the 
database. The relatively static nature of the taxonomy allows the information to be 
stored in data files. If the applet were to query the database it would have to be 
launched from the same server to satisfy applet security restrictions. We felt that 
there was no advantage to adding this restriction. Updating the taxonomy involves 
nothing more than editing a text file. By not accessing the database, the download 
time is greatly reduced. We divide the four levels of the taxonomy into separate data 
files. The first level is read in and displayed while the others are loading instead of 
waiting for the entire taxonomy before display. 

The data files are text files with a standard format. The parent term starts at 
character position 1 and the child term starts at character position 39. This format 
is required by the applet for correct parsing of the data. This format accommodates 
the longest string in the taxonomy in addition to a small buffer. This design feature 


allows any taxonomy (within design specifications) to be displayed with this system. 


B. JAVA CLASSES 


Java source code has a .java extension. Compiled Java code has a .class ex- 
tension. A class file is analogous to an executable file in other languages although it 
can not run without the JVM. Java’s platform independence is achieved by compil- 
ing source code to an intermediate level known as byte codes. The byte codes are 
object code for the JVM. The JVM interprets the object code to execute on the local 
platform. 

The following is a description of each class’ function and its interaction with 
the overall system. An object is an instance of a Java class. The distinction is small 
and they are often used interchangeably. ‘The term object can also be used as a generic 
label for a decision technology in this system. We refer to attributes as instances of 


variables in much the same way. A variable is a generic term such as Problem Area’. 
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An attribute is a child of that variable describing a particular technology object. 
Where appropriate, the DecisionNet Java Objects refer to the general Components 


described in Chapter III Section D. 


1. Dnet_Reg.class 

This applet allows a producer to explore the taxonomy and decide where his 
decision technology fits into it. This object implements the Object Classification 
Editor. (See Chapter III Section D) Once the technology is correctly classified, the 
applet interfaces with an existing CGI script (regteca.exe) [Ref. 7] to complete the 
registration. The applet allows specification down to four levels for each variable. 
The applet captures user information from the HTML page that launches it. The 
user information is required by the CGI script (regteca.exe). It utilizes the taronomy 


object as its main GUI. 


2. Dnet_Search.class 

This applet allows a consumer to explore the taxonomy and specify search 
criteria for the five variables. This object serves as the Search Criteria Editor. (See 
Chapter III Section D) The applet allows specification down to four levels for each 
variable. The applet utilizes the tazonomy object as its main GUI. It passes control 


and the search criteria to the weights object. 


3. Dnet_Browse.class 

This applet allows a consumer to browse the taxonomy . This object serves 
as the Taronomy Browser. (See Chapter III Section D) The applet allows browsing 
down to four levels for each variable. The applet utilizes the taxonomy object as its 


main GUI. 


4.  Taxonomy.class 
The taxonomy object is utilized by all three applets. It is the main GUI that 
displays the taxonomy and highlights user selections. The user controls the display 


by double clicking the left mouse button within a displayed list. If there are any 
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children of the selected term in the taxonomy, they are displayed in the adjacent list. 
This cascading refinement is highlighted in the text boxes above the lists. 

Appendix C contains a list of variables that are passed to the taxonomy object 
when one of the three applets calls it. Any parameters that do not apply are sent as 
a single space. All of these parameters originate in the HTML page that launches the 
applet. The applet reads them and passes the appropriate parameters to the other 


objects (taxonomy, weights, grep, etc.) as needed. 


5.  Weights.class 

The weights object accepts the search criteria and allows the user to adjust 
the variable weights and degradation multipliers used by the search algorithm. This 
object serves as the Search Parameters Editor. (See Chapter III Section D) Default 
values are provided through the input parameters. Equal weight is given to each 
variable and degradation multipliers are set to the expected probable value of a given 
relationship. The wezghts object passes control to the Search Algorithm (Indexed.exe) 


described in Section C. 


6. Search_Results.class 

The Search.Results object accepts the output from the /ndezed.eze script for 
display within the applet. This object serves as the Search Results Visualizer. (See 
Chapter III Section D) The datastream is parsed and formatted using control char- 
acters placed in the stream by the /ndezed.eze script. The user’s search criteria and 
variable weights are returned for review. Each relevant technology is displayed with 
a total score as well as individual attribute scores. This allows the user to see which 


attributes produced a relationship, and what type of relationship it is. 


7. Reg Complete.class 

The Reg_Complete object is a simple dialog screen that displays the success 
or failure of various operations. It is utilized by the DNET_Reg and DNET_Search 
applets. 
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8. MultiLineLabel.class 


At the time of coding, the Java language did not define a label of more than 


one line of text. This object provides that functionality. [Ref. 10] 


9. Grep.class 
This object is slightly modified from the cited source. Its only function is to 
discard lines that do not contained a given string. It receives lines of text from the 


GrepInputStream object along with the string to be matched. [Ref. 10] 


10. GrepInputStream.class 
This object is slightly modified from the cited source. Its only function is to 
read lines from an input stream. It passes each line to the Grep object along with the 


string to be matched. [Ref. 10] 


11. QueryString.class 
This object concatenates the variables into one string to be sent to either the 


registration (regteca.exe) or search (Indexed.exe) CGI script. 


C. DELPHI SEARCH SCRIPT 

The only component of this system that is not implemented in Java is the 
search algorithm. Once the decision to modify the all-Java solution was made, a 
Java search algorithm did not offer any advantages. The driving factor in going to 
a native code solution was speed. The search algorithm is computationally intensive 
and makes repeated queries to several database tables. The performance would be 
unacceptable given the current speed of Java code. Java code can be significantly 
slower than C code on average. [Ref. 10] Sun is currently working to improve the 


performance with the introduction of a Just-in-Time (JIT) Compiler. 


1. Indexed.exe 
This is the implementation of the Search Algorithm. (See Chapter III Sec- 


tion D) The search algorithm is designed to compute a relevancy score for technolo- 


Ze 


gies that may be of interest to a consumer conducting a search. The goal is to limit 
the number of records that need to be processed without discarding any that may 
be useful. The initial screening looks to find at least one direct match between the 
search criteria and a record attribute. Those records with a match are then eligible 
to be scored. As the number of records in the Technolo.db [Ref. 7] database increases 
this screening can be increased to require two or more matches before evaluating the 
record’s attribute relationships. 

For every record that is eligible, the algorithm checks each attribute to deter- 


mine if a relationship exists. The order of precedence follows: 


e Search Criteria = ALL, indicating no preference 
e Search Criteria is a direct match of the Attribute 


e Search Criteria is a child of the Attribute 


Search Criteria is a parent of the Attribute 


Search Criteria is a sibling of the Attribute 


Search Criteria is a descendant of the Attribute 


Search Criteria is a ancestor of the Attribute 


Queries are conducted through boolean gates that stop the process once a 
relationship has been established. Every eligible record is assigned five attribute 
scores. Once all of the relationships are established the algorithm computes a total 
score for each record. The relevancy score is a summation of the variable weights 
multiplied by the attribute score. This is shown notationally in Equation III.4. 

This implementation takes advantage of the strengths of each node of the 
client/server environment. The components are closely and logically tied to their data 
sources. Integration with the current system drove the continued use of CGI scripts. 
For most functions CGI scripts are efficient and robust, but they lack interaction. 


The combination of Java Applets and CGI scripts offers a reasonable alternative. 
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VI. SYSTEM TOUR 


The classification, registration, search, and retrieval functions are visual and 
intuitive. Once the applet is launched, a mouse is generally all that is required to 
navigate among the functions. The only time that the keyboard is required is to 
change the default values in the search engine. The following sections show the flow 


of control through the system as well as the various screens that a user will see. 


A. TECHNOLOGY REGISTRATION 

Producers of decision support technologies use this applet to correctly classify 
their decision technology within the DecisionNet taxonomy. (See Figure 8) All of 
the user information is supplied to the applet by the DecisionNet CGI script that 
produced the HTML page. Once the object classification is complete, the user presses 
the Submit for Registration’ button and control passes to the registration CGI script 


(regteca.exe). The success or failure of the registration process is displayed in Figure 9. 


B. CONSUMER SEARCH 


This applet allows a consumer to conduct a detailed search of the technology 
object database. The search engine allows the user to be as vague or as specific as he 
would like. He may specify any or all of the attributes that he is interested in. The 
default value of ALL’ will return a much wider range of responses than will a more 
specific selection. 

The Search Criteria Editor utilizes the same GUI shown in Figure 8 for its 
initial display. In the search configuration, the labels, instructions, and button func- 
tions have changed to reflect this role. This GUI allows the user to view and select 
from the entire taxonomy. Once the terms have been selected, the consumer pressed 
the "Define Search Weights’ button. Control then passes to the Search Parameters 
Editor shown in Figure 10. 
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Figure 8. Object Classification Editor 


The Search Parameters Editor allows a consumer to further refine their search. 
If certain variables are more or less important, the default weights should be changed. 
The five variable weights must sum to 1.0 or the results will be meaningless. The 
degradation factors allow a consumer to state the utility of various relationships 
that may exist between their search criteria and object attributes. The degradation 


multiplier is applied as follows: 


e If the criteria is a child of the attribute then the attribute receives a score 
equal to the child degradation multiplier. 


e If the criteria is a parent of the attribute then the attribute receives a score 
equal to the parent degradation multiplier. 


e If the criteria is a sibling of the attribute then the attribute receives a score 
equal to the sibling degradation multiplier. 
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Figure 9. Results Dialog Window 


e If the criteria is a descendant of the attribute then the attribute receives a 
score equal to the child degradation multiplier squared. 


e If the criteria is a ancestor of the attribute then the attribute receives a score 
equal to the parent degradation multiplier squared. 


Once the consumer has fully specified his search, he uses the Submit to Search 
Engine’ button to launch the search. The search algorithm is run through a CGI 
script and produces an output file that is returned to the applet. The script ends 
each line with the control characters ’/&’. This allows the applet to parse the stream 
of characters and recreate the form of the output file. The results are display in the 


Search Results Visualizer shown in Figure 11. 
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Figure 10. Search Parameters Editor 


C. TAXONOMY BROWSING 
This is the simplest of the three applets. It is used to browse the entire five 


variable, four dimensional taxonomy. The user can explore the possibilities and depth 
available in the system. Once the browser applet is downloaded, there is no need for 
further communication with the server. It will run entirely on the client. Figure 8 
again shows the taxonomy object. In the browser configuration, the labels, directions, 
and button functions have changed to reflect this role. The layout and control are 


identical. 
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Figure 11. Search Results Visualizer 
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VII. CONCLUSIONS 


A. CONTRIBUTIONS 


This thesis defines a methodology for classifying, registering, searching, and 
retrieving multi-variable objects in a digital repository. The methodology includes 
the definition of relationships that exist in a parent/child taxonomy. The compo- 
nents required to implement such a system are described in general terms and are 
demonstrated within DecisionNet. This framework can be applied to any system that 
classifies objects with a taxonomy and stores them in a digital library. 

The system developed for DecisionNet implements this methodology. It is 
both a testbed and a proof of concept. The ability to utilize the full taxonomy 
greatly enhances DecisionNet’s ability to bring producers and consumers of decision 
technologies together. The generalization that is integral to this thesis enables it to 
be applied to any systems that relies on a taxonometric classification scheme. The 
number of attributes and levels can be increased in the future to accommodate a 


larger taxonomy. 


B. LESSONS LEARNED 


The following is a list of lessons learned along the thesis path. 


e Repositories and code reuse hold a lot of promise for future projects. Java is 
not yet at this stage. 


e The conceptual understanding of what object oriented programming is and 
what it offers does not come immediately. This basic understanding is required 
before any real progress can be made. 


e Each decision made during analysis, design, and implementation effects the 
options available later in the development cycle. A good example is a naming 
convention. Planning and thought need to go into variable and object names 
before they become too cumbersome to change. 


e Documentation should be written simultaneously with the code. This proved 
very beneficial when trying to integrate Java code with Delphi code. 


of 


e Java is not a mature language. Java is developing quickly, but it has not 
reached the maturity level of many object oriented languages. Java lacks a 
good IDE that allows for the drag and drop construction of GUIs. There are 
attempts being made, but they currently lag behind those developed for other 
languages. 


e The key to running an applet within a web browser is the JVM. The JVM 
should interpret the applet bytecodes to run on any hardware and produce 
the same output regardless of the platform. This is not the case. There 
is a lack of standardization in the JVM implementation. This system was 
tested on several hardware platforms with different web browser combinations. 
The results were inconsistent. The basic functionality was adequate, but the 
display was awkward at times. 


C. LOOKING FORWARD 
This Thesis addresses and solves several areas that were identified in past 
DecisionNet thesis projects. The following topics are areas that remain for further 


research. 


1. Search Algorithm 

The search algorithm developed in this thesis establishes relationships for each 
attribute of a record that passes its initial screening. This works well in the current 
environment. As the object database grows in size, the efficiency of this approach 
will become a limiting factor. A clever indexing scheme will greatly improve the 
search efficiency. Another possibility is to establish relationships within the taxonomy 
and include them as an attribute in the taxonomy database. Chapter III Section C 
describes the dynamic determination of search depth based on search weight input. 


This will also improve the algorithm’s efficiency. 


2. Search Results Visualizer 

The Search Results Visualizer is currently a display of the output text file from 
the search algorithm’s CGI script. This data could be sorted and displayed in any 
number of ways that may be helpful to a consumer. ‘The following is a list of possible 


representations that would greatly enhance the impact and usability of the returned 
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data. 


Display total scores first, and allow the user to drill down to review individual 
attribute scores of promising technologies 


e A comparative bar chart to visually compare the relevance of different tech- 
nologies against each other and against the ideal case of 1.0 


A pie chart to display the user defined variable weights 


A sliding scale that could be dragged with a mouse to perform sensitivity 
analysis on weights and degradation factors 


An applet is the perfect vehicle to handle these tasks on the client machine. 


3. Three Tiered Client/Server 

The implementation of the three tiered client server design will be possible 
in the next 12 - 24 months. As the Java language and the support for it grows, 
an all-Java solution will take full advantage of distributed computing and storage of 


information. 


4. Help Menus 


The ability to right mouse click on a term or component would greatly add 
to the usability of the system. There are many technical and mathematical terms in 
the taxonomy that will not be familiar to the average user. Online amplification and 
definition would increase the effectiveness of the classification and search functions 


by answering questions as the arise. 
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APPENDIX A. SYMBOLS AND ACRONYMS 


Symbol => Name 


SQA EC HeEOE DY rar irop 


Delta 
delta 
Gamma 
gamma 
kappa 
Lambda 
lambda 
Omega 
omega 
Phi 

Psi 

psi 
sigma 
theta 


Acronym=> Meaning 


CGI 
DNET 
DSS 
GB 
GUI 
HTML 
IDE 
JIT 
JVM 
JDBC 
JDK 
KB 
MB 
MHz 
OS 
RAM 
RMI 
URL 
WWW 


Common Gateway Interface 
DecisionNet 

Decision Support System 
Gigabit 

Graphical User Interface 

Hyper Text Mark-Up Language 
Integrated Development Environment 
Just in Time 

Java Virtual Machine 

Java DataBase Connectivity 
Java Developer’s Kit 

Kilobit 

Megabit 

Megahertz 

Operating System 

Random Access Memory 
Remote Method Invocation 
Uniform Resource Locator 


World Wide Web 


4} 





APPENDIX B. TIPS FOR SYSTEM 
ADMINISTRATION 


The system design is focused on adaptability beyond DecisionNet. It is able to 
display and manipulate any taxonomy that fits within the five variable, four dimension 
limit. This is achieved by passing parameters from an HTML page into each applet. 
A standard list of parameters is passed each time an applet is called. Variables that 
do not apply are passed as a blank space. An example of this generality is the URL 
parameter. The implementation is not tied to any URL or domain name. If the class 
files, data files, or database are transferred to another server it requires only a change 
to the HTML parameter. 

The naming conventions and database design of DecisionNet were left un- 
touched. The variable names internal to the Java code are in some cases specific to 
DecisionNet. This is transparent to the user because the actual values are fed from 
the HTML page. Each parameter is discussed in detail in Appendix C. Appropriate 
values are defined were applicable. 

Each level of the taxonomy has its own data file. This was done to logically 
separate the taxonomy levels and to speed retrieval. The data files must conform 
to the standard format. The parent term starts at character position 1, followed by 
the child term at character position 39. The child term must be followed by a line 
break. This seemingly arbitrary number is two characters past the longest entry in the 
taxonomy. In the event that a taxonomy contains strings longer than 38 characters, 
the code of Grep.class would need to be altered and recompiled. The data files are 
stored as .txt files, and must be located in a WWW accessible directory along with 
the Java class files. 

The Java code was developed in the Microsoft Visual J++ integrated devel- 
opment environment (IDE). If it becomes necessary to change any of the Java source 


code it should be done through the IDE. The Dnet project file (Dnet.dsw) contains 
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links to all of the Dnet source files. The files can be recompiled as a project by se- 
lecting the "Rebuild All’ function from the ’Build’ pull down menu. The development 
platform was a Pentium (166 Mhz) with 64 MB of RAM. The operating system (OS) 
was Windows NT Workstation 4.0. The primary Web browser was Microsoft Internet 


Explorer 3.02. Netscape 3.0 and HotJava were used for test and evaluation only. 
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APPENDIX C. APPLET PARAMETERS 


PARAM NAMEF=title_input VALUE=” DecisionNet Registration Applet” This 
is the screen title that appears in the top left corner of the taxonomy screen. 
This may be changed at will. 


PARAM NAME=LeftButtonLabel_input VALUE=”Submit for Registration” 
There are only three acceptable values for this paramater. 

— Dnet_Reg.class requires the string "Submit for Registration”. 

— Dnet Search.class requires the string ” Define Search Weights”. 


~— Dnet_Browse.class requires the string ” Return to DecisionNet”. 


These strings are used to tailor the taxonomy object based on the applet that 
called it. If anything other than these strings is used, the left button of the 
taxonomy screen will not function. 


PARAM NAME=ProviderID_Input VALUE=”corgnati” This paramater is 
captured from a CGI script and inserted into HTML. Is a system defined 
user name. It is used by the registration applet. 


PARAM NAME=Consumer!ID_Input VALUE=” ” This paramater is captured 
from a CGI script and inserted into HTML. This is a system defined user name. 
It is used by the search applet. 


PARAM NAME=TechID_Input VALUE=”14” This paramater is captured 
from a CGI script and inserted into HTML. It is an index to track producers 
with multiple technologies registered. 


PARAM NAME=TechName_Input VALUE=” Test” This paramater is cap- 
tured from a CGI script and inserted into HTML. This is whatever the pro- 
ducer wants it to be. 


PARAM NAME=tObjectType_Input VALUE=” Solver” This parameter is 

captured from a CGI script and inserted into HTML. This is a relic from the 
original implimentation. It is included only to maintain integrity with the 
existing database and CGI scripts. The acceptable values for DecisionNet are: 


— ALL 

— Algorithm 

— Data Set 

— Decision Support System 
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— Example 
— Model Schema 
— Modeling Language 


— Solver 


PARAM NAME=tURL_Input VALUE=” http://131.120.39.60” This parame- 
ter is captured from a CGI script and inserted into HTML. It is the URL of 
the producer’s technology. 


PARAM NAME=ExcliInd_Input VALUE=” Independent” This parameter is 
captured from a CGI script and inserted into HTML. This is a flag used by 
AMPL technologies. It is included only to maintain integrity with the existing 
database and CGI scripts. 


PARAM NAME=Purpose_Input VALUE="none” This parameter is captured 
from a CGI script and inserted into HTML. It is a narrative description of the 
technology. 


PARAM NAME=Comments_Input VALUE=”none” This parameter is cap- 
tured from a CGI script and inserted into HTML. It is a narrative that allows 
for any additional information. 


PARAM NAME=ProviderID_db_Input VALUE =” ” This parameter repre- 
sents the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=ConsumerID_db_Input VALUE =” ” This parameter repre- 
sents the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=TechID_db_Input VALUE =” ” This parameter represents 
the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=‘TechName_db_Input VALUE =” ” This parameter repre- 
sents the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=tObjectType_db_Input VALUE =” ” This parameter repre- 
sents the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=tURL_db_Input VALUE =” ” This parameter represents the 
field name in the associated database. It is passed to the CGI scripts where 
required. 
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PARAM NAME=ExclInd_db_Input VALUE =” ” This parameter represents 
the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=Purpose_db_Input VALUE =” ” This parameter represents 
the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=Comments._db_Input VALUE =” ” This parameter repre- 
sents the field name in the associated database. It is passed to the CGI scripts 
where required. 


PARAM NAME=V1_Label_Input VALUE=”Problem Area” This is the label 
that will appear on the first button. It is also the string that will be searched 
for if the button is pressed. It is a parent term in the first level taxonomy data 
file. It should only be changed if using a taxonomy other than DecisionNet. 


PARAM NAME=V2_Label_Input VALUE=” Functional Area” This is the la- 
bel that will appear on the second button. It is also the string that will be 
searched for if the button is pressed. It is a parent term in the first level 
taxonomy data file. It should only be changed if using a taxonomy other than 
DecisionNet. 


PARAM NAME=V3_Label_Input VALUE=” Industry Type” This is the label 
that will appear on the third button. It is also the string that will be searched 
for if the button is pressed. It is a parent term in the first level taxonomy data 
file. It should only be changed if using a taxonomy other than DecisionNet. 


PARAM NAME=V4_Label_Input VALUE=” Organization Type” This is the 
label that will appear on the fourth button. It is also the string that will 
be searched for if the button is pressed. It is a parent term in the first level 
taxonomy data file. It should only be changed if using a taxonomy other than 
DecisionNet. 


PARAM NAME=V5_Label_Input VALUE=”Solution Method” This is the la- 
bel that will appear on the fifth button. It is also the string that will be 
searched for if the button is pressed. It is a parent term in the first level 
taxonomy data file. It should only be changed if using a taxonomy other than 
DecisionNet. 


PARAM NAME=Protocol_Input VALUE=” http” This is the default protocol. 
This should not be changed. 


PARAM NAME=Data_URL_Input VALUE=" 131.120.39.60” This is the URL 
of the Java code as well as the taxonomy data files. It should be changed to 
reflect to actual location of those files. 
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PARAM NAME=DB_URL-_Input VALUE=” 131.120.39.63” This is the URL 
of the DecisionNet database and CGI scripts. It should be changed to reflect 
to actual location of those files. 


PARAM NAME=Tax_L1_FileLoc_Input VALUE=” /Dnet/Tax_L1.txt” This is 
the directory location and file name of the taxonomy level 1 data file. It is 
relative to the WWW accessible root. These should be changed to reflect a 
new taxonomy or location. 


PARAM NAME=Tax_L2_FileLoc_Input VALUE=” /Dnet/Tax_L2.txt” This is 
the directory location and file name of the taxonomy level 2 data file. It is 
relative to the WWW accessible root. ‘These should be changed to reflect a 
new taxonomy or location. 


PARAM NAME=Tax_L3_FileLoc_Input VALUE=” /Dnet/Tax_L3.txt” This is 
the directory location and file name of the taxonomy level 3 data file. It is 
relative to the WWW accessible root. ‘These should be changed to reflect a 
new taxonomy or location. 


PARAM NAME=Tax-_L4_FileLoc_Input VALUE=” /Dnet/Tax_L4.txt” This is 
the directory location and file name of the taxonomy level 4 data file. It is 
relative to the WWW accessible root. These should be changed to reflect a 
new taxonomy or location. 


PARAM NAME=Reg Script_Loc_Input VALUE= 

” /egi-win/dnet/provider/regteca.exe” This is the directory location and file 
name of the registration script. It is relative to the WWW accessible root. It 
should be changed to reflect a new script or location. 


PARAM NAME=Search_Engine_Loc_Input VALUE=” ” This is the directory 
location and file name of the search algorithm. It is relative to the WWW 
accessible root. It should be changed to reflect a new script or location. 


PARAM NAME=Default_Weight_Input VALUE=” ” This paramater is used 
by the search algorith. It should be left at 0.2 to given even weight to all five 
variables. If fewer than 5 variables were utilized then it must be adjusted. 


PARAM NAME=Default_C_Deg_Input VALUE=” ” This paramater is used 
by the search algorithm. It is set 0.8. It can be adjusted if further research 
indicates a better default. 


PARAM NAME=Default_P_Deg_Input VALUE=” ” This paramater is used 
by the search algorithm. It is set 0.4. It can be adjusted if further research 
indicates a better default. 
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PARAM NAME=Default_S_Deg_Input VALUE=” ” This paramater is used 
by the search algorithm. It is set 0.6. It can be adjusted if further research 
indicates a better default. 


PARAM NAME=V1-cgi_label_Input VALUE=”tProblemArea” This parame- 
ter is specific to the DecisionNet database. It should be changed to reflect the 
actual field name of the first variable of a new database. 


PARAM NAME=V1-value_default_Input VALUE=” ALL” Default value for 
the initial display. 


PARAM NAME=V?2_cgi_label_Input VALUE=” tFunctionalArea” This param- 
eter is specific to the DecisionNet database. It should be changed to reflect 
the actual field name of the second variable of a new database. 


PARAM NAME=V2_value_default_Input VALUE=”ALL” Default value for 
the initial display. 


PARAM NAME=V3-cgi_label_Input VALUE=” tIndType” This parameter is 
specific to the DecisionNet database. It should be changed to reflect the actual 
field name of the third variable of a new database. 


PARAM NAME=V3-value_default_Input VALUE=” ALL” Default value for 
the initial display. 


PARAM NAME=V4-_cgi_label_Input VALUE=”"tOrgType” This parameter is 
specific to the DecisionNet database. It should be changed to reflect the actual 
field name of the fourth variable of a new database. 


PARAM NAME=V4_value_default_Input VALUE=” ALL” Default value for 
the initial display. 


PARAM NAME=V5-cgi-_label_Input VALUE=” tSolutionMethod” This 
parameter is specific to the DecisionNet database. It should be changed to 
reflect the actual field name of the fifth variable of a new database. 


PARAM NAME=V5_value_default_Input VALUE=” ALL” Default value for 
the initial display. 
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APPENDIX D. BROWSER APPLET 


] FOROS ORO AKIRA IKE 
// DNET_Browse. java: Applet 

// The DNET_Browse class is the applet that allows producers and 

// consumers to view and explore the full multi-dimensional taxonomy 
Vs 

// Copyright by: 
// 

// Last modified: 1300 08 Aug 1997 version 1.1 

] FORO OOOO OOOO OI IIa I KK 
import java.applet.*; 

import java.awt.*; 


LT Chris Corgnati for Thesis work with Prof Bhargava 


public class DNET_Browse extends Applet { 


//An HTML page must feed the following parameters to this applet 


String title_Param;String message_Param; 

String LeftButtonLabel_Param; 

String ProviderID_Param;String ConsumerID_Paran; 
String TechID_Param;String TechName_Param; 

String tO0bjectType_Param; 

String tURL_Param; 

String ExcInd_Param; 

String Purpose_Param;String Comments_Param; 

String ProviderID_db_Param;String ConsumerID_db_Paranm; 


String TechID_db_Param;String TechName_db_Param; 
String tObjectType_db_Param; 

String tURL_db_Param; 

String ExcInd_db_Param; 

String Purpose_db_Param;String Comments_db_Param; 
String Vi_Label_Param;String V2_Label_Param; 
String V3_Label_Param;String V4_Label_Param; 
String V5_Label_Param; 

String Protocol_Param;String Data_URL_Param; 
String DB_URL_Param;int Port_Param; 

String Tax_Li_FileLoc_Param;String Tax_L2_FileLoc_Param; 
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String Tax_L3_FileLoc_Param;String Tax_L4_FileLoc_Param; 
String Reg_Script_Loc_Param;String Search_Engine_Loc_Param; 


String Default_Weight_Param;String Default_C_Deg Param; 
String Default_P_Deg_Param;String Default_S_Deg Param; 


String Vi_cgi_label_Param;String V1l_value_default_Param; 
String V2_cgi_label_Param;String V2_value_default_Param; 
String V3_cgi_label_Param;String V3_value_default_Param; 
String V4_cgi_label_Param;String V4_value_default_Param; 
String V5_cgi_label_Param;String V5_value_default_Param; 


// DNET Class Constructor 
public DNET_Browse() { 
} 


// APPLET INFO SUPPORT: 
public String getAppletInfo() 


i 
return "Name: DNET\r\n" + 
"Author: LT Christopher M. Corgnati\r\n" + 
"Created with Microsoft Visual J++ Version 1.1"; 
i 


public void init() { 


this.title_Param = getParameter("title_input") ; 
this.LeftButtonLabel_Param = 

getParameter ("LeftButtonLabel_input") ; 
this.ProviderID_Param = getParameter("ProviderID_Input") ; 
this.ConsumerID_Param = getParameter("ConsumerID_Input") ; 
this.TechID_Param = getParameter("TechID_Input") ; 
this.TechName_Param = getParameter("TechName_Input") ; 
this.tObjectType_Param = getParameter("tObjectType_Input") ; 
this.tURL_Param = getParameter("tURL_Input") ; 
this.ExcInd_Param = getParameter("ExcInd_Input") ; 
this.Purpose_Param = getParameter("Purpose_Input") ; 
this.Comments_Param = getParameter ("Comments_Input") ; 


this.ProviderID_db_Param = getParameter("ProviderID_db_Input") ; 
this.ConsumerID_db_Param = getParameter("ConsumerID_db_Input") ; 
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this.TechID_db_Param 
this.TechName_db_Param 
this.tObjectType_db_Param 
this. tURL_db_Param 
this.ExcInd_db_Param 
this .Purpose_db_Param 
this.Comments_db_Param 


getParameter("TechID_db_Input") ; 

= getParameter("TechName_db_Input") ; 
getParameter("tObjectType_db_Input") ; 

getParameter ("tURL_db_Input") ; 

getParameter ("ExcInd_db_Input") ; 

getParameter ("Purpose_db_Input") ; 

getParameter ("Comments_db_Input") ; 


this. Vi_Label_Param 
this. V2_Label_Param 
this.V3_Labe._Param 
this.V4_Label_Param 
this. V5_Label_Param 


getParameter("Vi_Label_Input") ; 
getParameter("V2_Label_Input") ; 
getParameter("V3_Label_Input") ; 
getParameter("V4_Label_Input") ; 
getParameter("V5_Label_Input") ; 


this.Protocol_Param = 
this.Data_URL_Param 
this .DB_URL_Param 
Port_Param = 80; 


getParameter("Protocol_Input") ; 
getParameter("Data_URL_Input") ; 
getParameter("DB_URL_Input") ; 


this. Tax_Li_FileLoc_Param 
this .Tax_L2_FileLoc_Param = 
this.Tax_L3_FileLoc_Param 
this.Tax_L4_FileLoc_Param 
this.Reg_Script_Loc_Param 


this.Search_Engine_Loc_Param 


getParameter("Search_En 
this .Default_Weight_Param 
this.Default_C_Deg_Param 
this.Default_P_Deg_ Param 
this .Default_S_Deg_ Param 


this.Vi_cgi_label_Param = g 
this.Vi_value_default_Param 
getParameter("Vi_value_ 
this.V2_cgi_label_Param = g 
this. V2_value_default_Param 
getParameter ("V2_value_ 
this.V3_cgi_label_Param = g 
this. V3_value_default_Param 
getParameter ("V3_value_ 
this.V4_cgi_label_Param = g 
this. V4_value_default_Param 
getParameter ("V4_value_ 


getParameter ("Tax_Li_FileLoc_Input") ; 
getParameter("Tax_L2_FileLoc_Input") ; 
getParameter ("Tax_L3_FileLoc_Input") ; 
getParameter ("Tax_L4_FileLoc_Input") ; 
getParameter ("Reg _Script_Loc_Input") ; 


eine_Loc_Inpucliee 
getParameter("Default_Weight_Input") ; 
getParameter("Default_C_Deg_ Input") ; 
getParameter("Default_P_Deg_ Input") ; 
getParameter("Default_S_Deg_ Input") ; 


etParameter("Vi_cgi_label_Input") ; 


default_Input") ; 
etParameter("V2_cgi_label_Input") ; 


default_Input") ; 
etParameter("V3_cgi_label_Input") ; 


default_Input") ; 
etParameter("V4_cgi_label_Input") ; 


default_Input") ; 


oo 


this.V5_cgi_label_Param = getParameter("V5_cgi_label_Input") ; 
this.V5_value_default_Param = 
getParameter("V5_value_default_Input") ; 


This calls the Taxonomy screen. Message can be changed here 
Frame £3 = new Frame(); 


Taxonomy T = new Taxonomy(f3,title_Paran, 
"Please use this browser to explore this multi-variable, 
multi-dimensional taxonomy. Use the \n" 
+"?Return’ button to cancel the applet. A double click on an 
item will reveal any items below \n" 
+"it in the Taxonomy. It will also highlight your choice in 
the boxe> above the lists. \n" 
+"This Applet is written in Java By LT Chris Corgnati.\n", 
LeftButtonLabel_Param,ProviderID_Param,TechID_Paran, 
TechName_Param,tQbjectType_Param, tURL_Param,ExcInd_Param, 
Purpose_Param,Comments_Param,ConsumerID_Param,V1_Label_Paran, 
V2_Label_Param,V3_Label_Param,V4_Label_Param,V5_Label_Paranm, 
Protocol_Param,Data_URL_Param,DB_URL_Param,Port_Paranm, 
Tax_L1_FileLoc_Param,Tax_L2_FileLoc_Paran, 
Tax_L3_FileLoc_Param, Tax_L4_FileLoc_Paranm, 
Reg_Script_Loc_Param,Search_Engine_Loc_Param, 
Default_Weight_Param,Default_C_Deg_Param,Default_P_Deg_Paran, 
Default_S_Deg_Paran, 
Vi_cgi_label_Param,Vi_value_default_Param, 
V2_cgi_label_Param,V2_value_default_Param, 
V3_cgi_label_Param,V3_value_default_Param, 
V4_cgi_label_Param,V4_value_default_Paran, 
V5_cgi_label_Param,V5_value_default_Paran, 
ConsumerID_db_Param,ProviderID_db_Paran, 
TechID_db_Param,TechName_db_Param,tOQbjectType_db_Param, 
tURL_db_Param,ExcInd_db_Param, Purpose_db_Paran, 
Comments_db_Param) ; 


T.resize(700,700) ; 
T show Oe 
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APPENDIX E. REGISTRATION APPLET 


] ROO OOOO GIO ORI OR OC CRI IR I I I aK I 3 2 ak 2k 2k 2k 2k 2k 2k 
// DNET_Reg.java: Applet 

// The DNET_Reg class is the applet that allows producers to register 
// thier technologies with the full multi-dimensional taxonomy 

va 

// Copyright by: 
A | 
// Last modified: 1300 08 Aug 1997 version 1.1 

] 2 OOO OO I IOI GIG GGG GI I IO I I I I ak ak ak 2k 2k 
import java.applet.*; 

import java.awt.*; 


LT Chris Corgnati for Thesis work with Prof Bhargava 


public class DNET_Reg extends Applet { 


//An HTML page must feed the following parameters to this applet 


String title_Param;String message_Param; 

string LeftButtonLabel_Param; 

String ProviderID_Param;String ConsumerID_Param; 
String TechID_Param;String TechName_Param; 

String tQbjectType_Paran ; 

String tURL_Param; 

String ExcInd_Param; 

String Purpose_Param;String Comments_Param; 

String ProviderID_db_Param;String ConsumerID_db_Param; 
String TechID_db_Param;String TechName_db_Param; 
String tObjectType_db_Param; 

String tURL_db_Param; 

String ExcInd_db_Param; 

String Purpose_db_Param;String Comments_db_Param; 
String Vi_Label_Param;String V2_Label_Param; 

String V3_Label_Param; String V4_Label_Param; 

String V5_Label_Param; 

String Protocol_Param;String Data_URL_Paran; 

String DB_URL_Param;int Port_Param; 

String Tax_Li_FileLoc_Param;String Tax_L2_FileLoc_Param; 
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String Tax_L3_FileLoc_Param;String Tax_L4_FileLoc_Param; 
String Reg_Script_Loc_Param;String Search_Engine_Loc_Paran; 


String Default_Weight_Param;String Default_C_Deg_Param; 
String Default_P_Deg_Param;String Default_S_Deg_Param; 


String Vi_cgi_label_Param;String Vi_value_default_Param; 
String V2_cgi_label_Param;String V2_value_default_Param; 
String V3_cgi_label_Param;String V3_value_default_Param; 
String V4_cgi_label_Param;String V4_value_default_Param; 
String V5_cgi_label_Param;String V5_value_default_Param; 


// Constructor Code 
public DNET_Reg() { 
} 


// APPLET INFOQ SUPPORT: 
public String getAppletInfo() 


tt 
return "Name: DNET\r\n" + 
"Author: LT Christopher M. Corgnati\r\n" + 
"Created with Microsoft Visual J++ Version 1.1"; 
} 


public void init() { 


this.title_Param = getParameter("title_input") ; 
this.LeftButtonLabel_Param = 
getParameter("LeftButtonLabel_input") ; 
this.ProviderID_Param = getParameter("ProviderID_Input") ; 
this.ConsumerID_Param = getParameter("ConsumerID_Input") ; 
this.TechID_Param = getParameter("TechID_Input") ; 
this.TechName_Param = getParameter("TechName_Input") ; 
this.tObjectType_Param = getParameter("tObjectType_Input") ; 
this.tURL_Param = getParameter("tURL_Input") ; 
this.ExcInd_Param = getParameter ("ExcInd_Input") ; 
this.Purpose_Param = getParameter("Purpose_Input") ; 
this.Comments_Param = getParameter("Comments_Input") ; 


this.ProviderID_db_Param = getParameter("ProviderID_db_Input") ; 
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this 
this 
this 
this 
this 
this 
this 
this 


this 
this 
this 
this 
this 


this 
this 
this 
Port 
this 
this 
this 
this 
this 
this 


Gis 
this 
this 
this 


this 
this 


this 
this 


this 
this 


this 


.ConsumerID_db_Param = getParameter("ConsumerID_db_Input") ; 
.TechID_db_Param = getParameter("TechID_db_Input") ; 
.TechName_db_Param = getParameter("TechName_db_Input") ; 
.tObjectType_db_Param = getParameter("tObjectType_db_Input") ; 
.tURL_db_Param = getParameter("tURL_db_Input") ; 
.ExcInd_db_Param = getParameter("ExcInd_db_Input") ; 
.Purpose_db_Param = getParameter("Purpose_db_Input") ; 
.Comments_db_Param = getParameter("Comments_db_Input") ; 


.Vi_Label_Param = getParameter("Vi_Label_Input") ; 
.V2_Label_Param = getParameter("V2_Label_Input") ; 
.V3_Label_Param = getParameter("V3_Label_Input") ; 
.V4_Label_Param = getParameter("V4_Label_Input") ; 
.V5_Label_Param = getParameter("V5_Label_Input") ; 


.Protocol_Param = getParameter("Protocol_Input") ; 
.Data_URL_Param = getParameter("Data_URL_Input") ; 
.DB_URL_Param = getParameter("DB_URL_Input") ; 

_Param = 80; 

.Tax_Li_FileLoc_Param = getParameter("Tax_L1_FileLoc_Input") ; 
.Tax_L2_FileLoc_Param = getParameter("Tax_L2_FileLoc_Input") ; 
.Tax_L3_FileLoc_Param = getParameter("Tax_L3_FileLoc_Input") ; 
.Tax_L4_FileLoc_Param = getParameter("Tax_L4_FileLoc_Input") ; 
.Reg_Script_Loc_Param = getParameter("Reg_ Script_Loc_Input") ; 
.oearch Engine_Loc_Param = 

getParameter ("Search_Engine_Loc_Input") ; 
.Default_Weight_Param = getParameter("Default_Weight_Input") ; 
.Default_C_Deg_Param = getParameter("Default_C_Deg_Input") ; 
.Default_P_Deg_Param = getParameter("Default_P_Deg_Input") ; 
.Default_S_Deg Param = getParameter("Default_S_Deg_ Input") ; 


.Vi_cgi_label_Param = getParameter("Vi_cgi_label_Input") ; 
.Vi_value_default_Param = 
getParameter("V1_value_default_Input") ; 
.V2_cgi_label_Param = getParameter("V2_cgi_label_Input") ; 
.V2_value_default_Param = 
getParameter("V2_value_default_Input") ; 
.V3_cgi_label_Param = getParameter("V3_cgi_label_Input") ; 
.V3_value_default_Param = 
getParameter("V3_value_default_Input") ; 
.V4_cgi_label_Param = getParameter("V4_cgi_label_Input") ; 


this.V4_value_default_Param = 


of 
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getParameter("V4_value_default_Input") ; 
this.V5_cgi_label_Param = getParameter("V5_cgi_label_Input") ; 
this. V5_value_default_Param = 

getParameter("V5_value_default_Input") ; 


This calls the Taxonomy screen. Message can be changed here 
Frame fi = new Frame(); 


Taxonomy T = new Taxonomy(f1,title_Param, 
"Please use this browser to classify and register objects 
within the system. \n" 
+"Use the ’Submit’ button to register your object. Use the 
Return’ button to cancel \n" 
+"the applet. A double click on an item will reveal any items 
below it in the Taxonomy. \n" 
+"Tt will also highlight your choice in the boxes above the 
lists. \n" 
+"This Applet is written in Java By LT Chris Corgnati.\n", 
LeftButtonLabel_Param,ProviderID_Param,TechID_Paran, 
TechName_Param,tObjectType_Param, tURL_Param,ExcInd_Paran, 
Purpose_Param,Comments_Param,ConsumerID_Param,Vi_Label_Paran, 
V2_Label_Param,V3_Label_Param,V4_Label_Param,V5_Label_Paran, 
Protocol_Param,Data_URL_Param,DB_URL_Param,Port_Paran, 
Tax_Li_FileLoc_Param,Tax_L2_FileLoc_Paran, 
Tax_L3_FileLoc_Param, Tax_L4_FileLoc_Paran, 
Reg_Script_Loc_Param,Search_Engine_Loc_Paran, 
Default_Weight_Param,Default_C_Deg_Param,Default_P_Deg Param, 
Default_S_Deg_ Param, 
Vi_cgi_label_Param,V1i_value_default_Paran, 
V2_cgi_label_Param,V2_value_default_Paran, 
V3_cgi_label_Param,V3_value_default_Paran, 
V4_cgi_label_Param,V4_value_default_Paran, 
Vo_cgi_label_Param,V5_value_default_Paran, 
ConsumerID_db_Param,ProviderID_db_Paran, 
TechID_db_Param, TechName_db_Param,tObjectType_db_Param, 
tURL_db_Param,ExcIiInd_db_Param,Purpose_db_Paran, 
Comments_db_Param) ; 


T. resize (700,700) ; 


T.show() ; 
[ 


08 


APPENDIX F. SEARCH APPLET 


] [ORC ROR ROR OR OG IGOR III aE aE 
// DNET_Search. java: Applet 

// The DNET_Search class is the applet that controls the inputs to the 
// search algorithm and displays the results 

Td 

// Copyright ibys 
U7. 

// Last modified: 1350 08 Aug 1997 Version 1.1 

] [RRR FOR ORO ORO OOO GR I a IK a a a a a 
import java.applet.*; 

import java.awt.*; 


LT Chris Corgnati for Thesis work with Prof Bhargava 


public class DNET_Search extends Applet { 


//An HTML page must feed the following parameters to this applet 


String title_Param;String message_Param; 

String LeftButtonLabel_Param; 

String ProviderID_Param;String ConsumerID_Param; 
String TechID_Param;String TechName_Param; 

String tQ0bjectType_Param; 

String tURL_Param; 

String ExcInd_Paran; 

String Purpose_Param;String Comments_Param; 

String ProviderID_db_Param;String ConsumerID_db_Param; 


String TechID_db_Param;String TechName_db_Param; 
String tQbjectType_db_Paran ; 

String <«tURbadbukaramy 

String ExcInd_db_Param; 

String Purpose_db_Param;String Comments_db_Param; 
String Vi_Label_Param;String V2_Label_Param; 
String V3_Label_Param;String V4_Label_Param; 
String V5_Label_Param; 

String Protocol_Param;String Data_URL_Param; 
String DB_URL_Param;int Port_Param; 

String Tax_L1_FileLoc_Param;String Tax_L2_FileLoc_Param; 
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String Tax_L3_FileLoc_Param;String Tax_L4_FileLoc_Param; 
String Reg_Script_Loc_Param;String Search_Engine_Loc_Param; 


String Default_Weight_Param;String Default_C_Deg Param; 
String Default_P_Deg_Param;String Default_S_Deg Param; 


String Vi_cgi_label_Param;String Vi_value_default_Param; 
String V2_cgi_label_Param;String V2_value_default_Param; 
String V3_cgi_label_Param;String V3_value_default_Param; 
String V4_cgi_label_Param;String V4_value_default_Param; 
String V5_cgi_label_Param;String V5_value_default_Param; 


// Constructor Code 
public DNET_Search() i! 
i 


// APRLET INEO*SUPPOR®: 
public String getAppletInfo() 


i 
return "Name: DNET\r\n" + 
"Author: LT Christopher M. Corgnati\r\n" + 
"Created with Microsoft Visual J++ Version 1.1"; 
i 


public void initQ { 


this.title_Param = getParameter("title_input") ; 
this.LeftButtonLabel_Param = 
getParameter("LeftButtonLabel_input") ; 
this.ProviderID_Param = getParameter("ProviderID_Input") ; 
this.ConsumerID_Param = getParameter("ConsumerID_Input") ; 
this.TechID_Param = getParameter("TechID_Input") ; 
this.TechName_Param = getParameter("TechName_Input") ; 
this.tObjectType_Param = getParameter("tObjectType_Input") ; 
this.tURL_Param = getParameter("tURL_Input") ; 
this.ExcInd_Param = getParameter ("ExcInd_Input") ; 
this.Purpose_Param = getParameter("Purpose_Input") ; 
this.Comments_Param = getParameter("Comments_Input") ; 


this .ProviderID_db_Param 
this.ConsumerID_db_Param 


getParameter("ProviderID_db_Input") ; 
getParameter("ConsumerID_db_Input") ; 
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this.TechID_db_Param = getParameter("TechID_db_Input") ; 
this.TechName_db_Param = getParameter("TechName_db_Input") ; 
this.tObjectType_db_Param = getParameter("tObjectType_db_Input") ; 
this.tURL_db_Param = getParameter("tURL_db_Input") ; 
this.ExcInd_db_Param = getParameter("ExcInd_db_Input") ; 
this.Purpose_db_Param = getParameter("Purpose_db_Input") ; 
this.Comments_db_Param = getParameter("Comments_db_Input") ; 


this.Vi_Label_Param = getParameter("V1_Label_Input") ; 
this.V2_Label_Param = getParameter("V2_Label_Input") ; 
this.V3_Label_Param = getParameter("V3_Label_Input") ; 
this.V4_Label_Param = getParameter("V4_Label_Input") ; 
this.V5_Label_Param = getParameter("V5_Label_Input") ; 


this.Protocol_Param = getParameter("Protocol_Input") ; 
this.Data_URL_Param = getParameter("Data_URL_Input") ; 
this.DB_URL_Param = getParameter("DB_URL_Input") ; 
Port_Param = 80; 
this.Tax_Li_FileLoc_Param = getParameter("Tax_L1_FileLoc_Input") ; 
this.Tax_L2_FileLoc_Param = getParameter("Tax_L2_FileLoc_Input") ; 
this.Tax_L3_FileLoc_Param = getParameter ("Tax_L3_FileLoc_Input") ; 
this.Tax_L4_FileLoc_Param = getParameter("Tax_L4_FileLoc_Input") ; 
this.Reg_Script_Loc_Param = getParameter("Reg_Script_Loc_Input") ; 
this.Search_Engine_Loc_Param = 
getParameter("Search_Engine_Loc_Input") ; 
this.Default_Weight_Param = getParameter("Default_Weight_Input") ; 
this.Default_C_Deg Param = getParameter("Default_C_Deg_Input") ; 
this.Default_P_Deg_ Param = getParameter("Default_P_Deg_Input") ; 
this.Default_S_Deg_Param = getParameter("Default_S_Deg_ Input") ; 


| 


this.Vi_cgi_label_Param = getParameter("V1_cgi_label_Input") ; 
this.Vi_value_default_Param = 
getParameter("V1i_value_default_Input") ; 
this.V2_cgi_label_Param = getParameter("V2_cgi_label_Input") ; 
this.V2_value_default_Param = 
getParameter("V2_value_default_Input") ; 
this.V3_cgi_label_Param = getParameter("V3_cgi_label_Input") ; 
this. V3_value_default_Param = 
getParameter ("V3_value_default_Input") ; 
this.V4_cgi_label_Param = getParameter("V4_cgi_label_Input") ; 
this.V4_value_default_Param = 
getParameter("V4_value_default_Input") ; 
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// 


this.V5_cgi_label_Param = getParameter("V5_cgi_label_Input") ; 
this.V5_value_default_Param = 
getParameter("V5_value_default_Input") ; 


This calls the Taxonomy screen. Message can be changed here 
Frame £2 = new Frame(); 


Taxonomy T = new Taxonomy (f2,title_Paran, 
"Welcome to the Search Engine. Please use this applet to 
specify your preferences \n" 
+"and objectives for the search algorithm. Press ’Define 
Search Weights’ to move to \n" 
+"the nexitesereehee Press ’Return’ to cancel thevapplet. 
A double click on an item will \n" 
+"reveal any items below it in the Taxonomy. It will also 
highlight your choice in the top boxes. \n" 
+"This Applet is written in Java By LT Chris Corgnati.\n", 
LeftButtonLabel_Param,ProviderID_Param,TechID_Paran, 
TechName_Param, tObjectType_Param, tURL_Param,ExcInd_Paran, 
Purpose_Param,Comments_Param,ConsumerID_Param,Vi_Label_Paran, 
V2_Label_Param,V3_Label_Param,V4_Label_Param,V5_Label_Paran, 
Protocol_Param,Data_URL_Param,DB_URL_Param,Port_Paran, 
Tax_L1_FileLoc_Param, Tax_L2_FileLoc_Paran, 
Tax_L3_FileLoc_Param, Tax_L4_FileLoc_Paran, 
Reg_Script_Loc_Param,Search_Engine_Loc_Paran, 
Default_Weight_Param,Default_C_Deg_Param,Default_P_Deg_Paran, 
Default_S_Deg_Paran, 
Vi_cgi_label_Param, Vi_value_default_Paran, 
V2_cgi_label_Param,V2_value_default_Paran, 
V3_cgi_label_Param, V3_value_default_Paran, 
V4_cgi_label_Param, V4_value_default_Paran, 
V5_cgi_label_Param,V5_value_default_Paran, 
ConsumerID_db_Param,ProviderID_db_Paran, 
TechID_db_Param, TechName_db_Param,tObjectType_db_Paran, 
tURL_db_Param ,ExcInd_db_Param,Purpose_db_Paran, 
Comments_db_Param) ; 


T.resize(700, 700); 
T.show(); 
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// The Taxonomy class is the main interface for all of the Dnet 


// applets 
// Copyright by: 
// Prof Bhargava 
// Last modified: 


// 
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APPENDIX G. TAXONOMY 


import java.awt.+; 
import java.1o.*; 
import java.net.*; 
import java.applet.*; 


12 Aug 1997 


public class Taxonomy extends Frame { 


// 
// 
Te 


i 
kf 
// 


// 
// 


//Flags 
private 
private 
private 


private 
private 
private 
private 
private 


private 
private 
private 
private 


private 
private 
private 
private 


private 
private 
private 
private 


that pass control internal to this 


static 
static 
static 


static 
static 
static 
static 
static 


static 
static 
static 
static 


static 
static 
static 
static 


static 
static 
static 
static 


final 
final 
final 


final 
final 
final 
final 
final 


final 
final 
final 
final 


final 
final 
final 
final 


final 
final 
f iia] 
final 


arate 
int 
int 


alerts 
choke 
ant 
int 
int 


int 
int 
Aa 
int 


int 
ne one 
Inc 
Tate 


ata 
‘lira 
eat 
Daye 


cancel 
submit 
search 


Vi_button_token = 
V2_button_token = 
V3_button_token = 
V4_button_token = 
VS5_button_token = 


Vi_toke 


n 


V2_token 
V2_2D_ token = 


V2_3D_token 
V2_4D_token = 


V3_token 
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ee 
V1_2D_token 
Vi_3D_token 
Vi_4D_token 


=i; 


= 15; 
V3_2D_token 
V3_3D_token 
V3_4D_token 


a5 


Oz 


Ve? 
AS 
ee 


ion 
re 
1S: 


LT Chris Corgnati for Thesis work with 


Version 1.2 


object 


Oo SP W NY 


ms © ~~ we 


ws © 


//future 
hi/ Exeume 
//Lutume 


//future 
SE apheincts 
//future 


//future 
//future 
//future 


use 
use 
use 


use 
use 
use 


use 
use 
use 


private static final int V4_token = 19; 
private static final int V4_2D_token 
private static final int V4_3D_token 
private static final int V4_4D_token 


20; //future use 
2; //Gubarcsuse 
22:0 //tuturesuse 


private static final int V5_token = 23; 


private static final int V5_2D_token = 24; 
private static final int V5_3D_token = 25; 
private static final int V5_4D_token = 26; 


// Nalue strings are set to the parameter strings passed from HTML 
String ProviaerID_Value = new String(ProviderID_Param) ; 

String ConsumerID_Value = new String(ConsumerID_Param) ; 

String TechID_Value = new String(TechID_Param) ; 

String TechName_Value = new String(TechName_Param) ; 

String tObjectType_Value = new String(tObjectType_Param) ; 

String tURL_Value = new String(tURL_Param) ; 

String ExcInd_Value = new String(ExcInd_Param) ; 

String Purpose_Value = new String(Purpose_Param) ; 

String Comments_Value = new String(Comments_Param) ; 


//these represent the database column names-passed from HTML 
String ConsumerID_db_value = new String (ConsumerID_db) ; 
String ProviderID_db_value = new String (ProviderID_db) ; 
String TechID_db_value = new String(TechID_db) ; 

String TechName_db_value = new String(TechName_db) ; 

String tObjectType_db_value = new String (tObjectType_db) ; 
String tURL_db_value = new String(tURL_db) ; 

String ExcInd_db_value = new String(ExcInd_db) ; 

String Purpose_db_value = new String(Purpose_db) ; 

String Comments_db_value = new String(Comments_db) ; 


//putton labels 

String Vi_Label = new String(V1_Label_Param) ; 
String V2_Label = new String(V2_Label_Param) ; 
String V3_Label = new String(V3_Label_Param) ; 
String V4_Label = new String(V4_Label_Param) ; 
String V5_Label = new String(V5_Label_Param) ; 


//Networking variables and file locations 
String Protocol = new String(Protocol); 
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String Data_File_Home = new String(Data_URL) ; 

String Database_Home = new String(DB_URL) ; 

ieee Orh = Port ; 

String Tax_L1 = new String(Tax_L1_FileLoc) ; 

String Tax_L2 = new String(Tax_L2_FileLoc) ; 

String Tax_L3 = new String(Tax_L3_FileLoc) ; 

String Tax_L4 = new String(Tax_L4_FileLoc) ; 

String cgi_regteca = new String(Reg_Script_Loc) ; 

String Search_Engine_Loc = new String(Search_Engine_Loc) ; 


M 


Hl 


i 


//default search values 

String Default_Weight = new String(Default_Weight_Param) ; 
String Default_C_Deg = new String(Default_C_Deg Param) ; 
String Default_P_Deg = new String(Default_P_Deg Param) ; 
String Default_S_Deg = new String(Default_S_Deg_ Param) ; 


//cgi and database names, and default values for initial display 
String Vi_cgi_label = new String(Vi_cgi_label) ; 
String Vi_Value = new String(V1_value_default) ; 
String V2_cgi_label = new String(V2_cgi_label) ; 
String V2_Value = new String(V2_value_default) ; 
String V3_cgi_label = new String(V3_cgi_label1) ; 
String V3_Value = new String(V3_value_default) ; 
String V4_cgi_label = new String(V4_cgi_labe1l) ; 
String V4_Value = new String(V4_value_default) ; 
String V5_cgi_label = new String(V5_cgi_label1) ; 
String V5_Value = new String(V5_value_default) ; 


private int List_Token; //shows the active list 


Button Submit,Cancel,Vi_Button, V2_Button, 
V3_Button, V4_Button,V5_Button; 


MultiLineLabel Narrative; 


List Level_1,Level_2,Level_3,Level_4; 
TextField V1_Field,V1_2D_Field, 
Vi_3D_Field,V1_4D_Field; 
TextField V2_Field,V2_2D_ Field, 
V2_3D_Field,V2_4D_Field; 
TextField V3_Field,V3_2D_Field, 
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V3_3D_Field, V3_4D_Field; 


TextField V4_Field,V4_2D_Field, 
V4_3D_Field,V4_4D_Field; 
TextField V5_Field,V5_2D_Field, 


V5_3D_Field, V5_4D_Field; 
TextField Current_Field,Message_Field; 
GridBagLayout gridbag = new GridBagLayout() ; 
InputStream input; 


String querystring; 
// value is used to differentiate which applet is calling 
String button_label = new String (Submit_Button_Label) ; 


// Constuctor Code-instances of taxonomy must call it with this info 


public Taxonomy(Frame f,String title,String message, 
String Submit_Button_Label, 
string ProviderID_Param,String TechID_Paran, 
String TechName_Param,String tObjectType_Paran, 
String tURL_Param,String ExcInd_Param,String Purpose_Paran, 
String Comments_Param,String ConsumerID_Param, 
String Vi_Label_Param,String V2_Label_Paran, 
String V3_Label_Param,String V4_Label_Param, 
String Vo_Label_Param,String Protocol, 
String Data_URL,String DB_URL,int Port,String Tax_Li_FileLoc, 
String Tax_L2_FileLoc,String Tax_L3_FileLoc, 
String Tax_L4_FileLoc, 
otring Reg _Script_Loc,String Search_Engine_Loc, 
String Default_Weight_Param,String Default_C_Deg_ Param, 
otring Default_P_Deg_Param,String Default_S_Deg_ Param, 
otring Vi_cgi_label,String Vi_value_default, 
String V2_cgi_label,String V2_value_default, 
string V3_cgi_label,String V3_value_default, 
String V4_cgi_label,String V4_value_default, 
string Vo_cgi_label,String V5_value_default, 
String ConsumerID_db,String ProviderID_db, 
String TechID_db,String TechName_db,String tObjectType_db, 
String tURL_db,String ExcInd_db,String Purpose_db, 
String Comments_db) { 
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super (title) ; 


// Panel 1i-Buttons 
Cancel = new Button ("Return to DecisionNet") ; 
Submit = new Button (Submit_Button_Label) ; 


Message_Field = new TextField(30) ; 
Message_Field.setEditable(false) ; 


Panel pi = new Panel(); 
p1.setLayout (gridbag) ; 


constrain(p1i,Submit,0,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENTER,0.0,0.0,10,10,10,10); 

constrain(pi,Message_Field,1,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENTER,0.0,0.0,10,10,10,10) ; 

constrain(pi,Cancel,2,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENTER,0.0,0.0,10,10,10,10) ; 


// Panel 2-Instructions 
Narrative = new MultiLineLabel (message, 1) ; 
Panel p2 = new Panel(); 
p2.setLayout (gridbag) ; 
constrain(p2,Narrative,0,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,0,0,0,0); 


// Panel 3-Selection Display 
Vi_Button = new Button (Vi_Label); 
V2_Button = new Button (V2_Label); 
V3_Button = new Button (V3_Label); 
V4_Button = new Button (V4_Label); 
V5_Button = new Button (V5_Label); 


Vi_Field = new TextField(18) ; 
Vi_Field.setText(V1i_Value) ; 
Vi_Field.setEditable(false) ; 

Vi_2D_ Field = new TextField(18) ; 
Vi_2D Field.setEditable(false) ; 

V1_3D_Field = new TextField(18) ; 
Vi1_3D_Field.setEditable(false) ; 

Vi_4D_Field = new TextField(18) ; 
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V1_4D_ Field ssetEditabletfalse): 


V2_Field = new TextField(18) ; 
V2_Field.setText (V2_Value) ; 
V2_Field.setEditable(false) ; 

V2_2D_ Field = new TextField(18) ; 
V2_2D_Field.setEditable (false) ; 

V2_3D_Field = new TextField(18) ; 
V2_3D_Field.setEditable(false); 

V2_4D_ Field = new TextField(18); 
V2_4D_Field.setEditable(false) ; 


V3_Field = new TextField(18) ; 
V3_Field.setText(V3_Value) ; 
V3_Field.setEditable(false) ; 

V3_2D_Field = new TextField(18); 
V3_2D_Field.setEditable(false) ; 

V3_3D_Field = new TextField(18) ; 
V3_3D_Field.setEditable(false) ; 

V3_4D_Field = new TextField(18) ; 
V3_4D_Field.setEditable(false) ; 


V4_Field = new TextField(18) ; 
V4_Field.setText(V4_Value) ; 
V4_Field.setEditable (false) ; 

V4_2D_Field = new TextField(18); 
V4_2D_Field.setEditable(false) ; 

V4_3D_Field = new TextField(18) ; 
V4_3D_Field.setEditable(false) ; 

V4_4D_ Field = new TextField(18); 
V4_4D_Field.setEditable(false) ; 


V5_Field = new TextField(18) ; 
V5_Field.setText(V5_Value) ; 
V5_Field.setEditable (false) ; 

V5_2D_ Field = new TextField(1i8): 
V5_2D_Field.setEditable(false) ; 

V5_3D_Field = new TextField(18): 
V5_3D_Field.setEditable(false) ; 

V5_4D_ Field = new TextField(18) ; 
V5_4D_Field.setEditable(false) ; 
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Panel p3 = new Panel(); 
p3.setLayout (gridbag) ; 


constrain(p3,V1_Button,1,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p3,V2_Button,1,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagGonstraints . CENTERRORO; OmOgelids, 1 ae 

constrain(p3,V3_Button,1,2,1,1,GridBagConstraints.HORIZONTAL, 
GeidBapConstraintssCENTER,Ou0nOn0el lydia 

constrain(p3, V4_Button,1,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p3,V5_Button,1,4,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p3,V1_Field,2,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagp@onstraintssCENTERMOF0 ;0s0mieey 1 | 14 
constrain(p3,V1_2D_Field,3,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p3,V1_3D_Field,4,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p3,V1_4D_Field,5,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p3,V2_Field,2,1,1,1,GridBagConstraints .HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p3,V2_2D_Field,3,1,1,1,GridBagConstraints.HORIZONTAL, 
GraidBagConstraints «CENTER, 0 .090a0¢ 1 pieaig 1); 

constrain (p3,V2_3D_Field,4,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p3,V2_4D_Field,5,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p3,V3_Field,2,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p3,V3_2D_Field,3,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain (p3,V3_3D_Field,4,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p3,V3_4D_Field,5,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CEN@ER ,0#0N0 05174 ,1,1); 


constrain(p3,V4_Field,2,3,1,1,GridBagConstraints .HORIZONTAL, 
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GridBagConstraints CENTER, 0-0, 07052; ia); 
constrain(p3,V4_2D_Field,3,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(p3, V4_3D_Field,4,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p3,V4_4D_Field,5,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p3,V5_Field,2,4,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p3,V5_2D_Field,3,4,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints. CENTER , 020,0n0ga), TT, ibs 
constrain(p3,V5_3D_Field,4,4,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(p3,V5_4D_Field,5,4,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints  CENTERRO? 0, OnOed, 1 de); 


// Panel 4-Display boxes for hierarchical levels 
Current_Field = new TextField(30) ; 
Current_Field.setEditable(false) ; 


Level_1 = @ew%List™(12) falsoe 
Level_2 = new List (12, false); 
beveiM@s = .tiemelist (lige Pallse) : 
Level_4 = new List (12, false); 


Panel p4 = new Panel(); 
p4.setLayout (gridbag) ; 


constrain(p4,Current_Field,2,0,2,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p4,Level_1,1,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p4,Level_2,2,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(p4, Level_3,3,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(p4,Level_4,4,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagCons traiinte: CENTER, O8050.0,1, 19151) 


// Add panels to the top level window and arrange the panels 
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this.setLayout (gridbag) ; 


constrain (this,p1,1,0,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain (this,p2,1,1,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain (this,p3,1,2,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4); 
constrain (this,p4,1,3,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4); 


// Event Handler 
public boolean action(Event event,0bject arg) { 
if (event.target instanceof Button) { 
if (event.target == Submit) { 
if (((String)event.arg).equals("Submit for Registration") ) 
answer (submit) ; 
else if (((String)event.arg).equals 
("Define Search Weights")) answer (search) ; 
else if (((String)event.arg) .equals 
("Return to DecisionNet")) answer (cancel) ; 
} 
else if (event.target 
else if (event.target = 
else if (event.target = 
else if (event.target = 
else if (event.target 
else answer(cancel) ; 
return true; 


Vi_Button) answer(V1_button_token) ; 
V2_Button) answer(V2_button_token) ; 
V3_Button) answer(V3_button_token) ; 
V4_Button) answer (V4_button_token) ; 
V5_Button) answer(V5_button_token) ; 


} 
if (event.target instanceof List) { 
if ((event.target == Level_1) & (List_Token == 111)) 
answer (V1i_token) ; 

1a else if ((event.target == Level_2) & (List_Token == 111)) 
ye answer(V1_2D_token) ; 
i] else if ((event.target == Level_3) & (List_Token == 111)) 
yy answer(V1_3D_token) ; 
yey else if ((event.target == Level_4) & (List_Token == 111)) 
// answer (V1_4D_token) ; 


else if ((event.target == Level_1) & (List_Token == 222)) 
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Ay 
a 
// 
// 
if 
// 


// 
Le 
17, 
// 


// 
i] 
Vi 
id 
// 
// 


} 


answer (V2_token) ; 
else if ((event.target == 
answer (V2_2D_token) ; 
else if ((event.target == 
answer (V2_3D_token) ; 
else if ((event.target == 
answer (V2_4D_token) ; 


else if ((event.target == 
answer (V3_token) ; 
else if ((event.target == 
answer (V3_2D_token) ; 
else if ((event.target == 
answer (V3_3D_token) ; 
else if ((event.target == 
answer (V3_4D_token) ; 


else if ((event.target == 
answer (V4_token) ; 
else if ((event.target == 
answer (V4_2D_token) ; 
else if ((event.target == 
answer (V4_3D_token) ; 
else if ((event.target == 
answer (V4_4D_token) ; 


else if ((event.target = 
answer (V5_token) ; 
else if ((event.target == 
answer (V5_2D_token) ; 
else if ((event.target == 
answer (V5_3D_token) ; 
else if ((event.target == 
answer (V5_4D_token) ; 


else answer(99); 
return true; 


else return false; 


t2 


Level_2) 
Level_3) 


Level_4) 


Level_1) 
Level_2) 
Level_3) 


Level_4) 


Level_1) 
Level_2) 
Level_3) 


Level _4) 


Level_1) 
Level?) 
Level_3) 


level) 


protected void answer(int answer) { 


(List_Token 
(List_Token 


(List_Token 


(List_Token 
(List_Token 
(List_Token 


(bast *Péken 


(List_Token 
(List_Token 
(List_Token 


(List_Token 


(List_ Token 
(List_Token 
(List_Token 


(List_Token 


992)) 
222) 


2220") 


Soc) 


333):) 


333)) 


323) ) 


444)) 


444) ) 


444)) 


444)) 


= 555)) 


5550) 
555) ) 


So) 


switch(arswer) { 

case cancel:cancel_handler() ; break; 
case submit: submit_handler() ; break; 
case search:search_handler() ; break; 


case Vi_button_token:Vi_button_handler() ; break; 
case V2_button_token: V2_button_handler() ; break; 
case V3_button_token: V3_button_handler() ; break; 
case V4_button_token:V4_button_handler() ; break; 
case V5_button_token:V5_button_handler() ; break; 


case Vi_token:Vi_handler () ; break; 


Ty, case V1_2D_token:V1_2D_handler() ; break; 
// case Vi_3D_token:Vi_3D_handler() ; break; 
yy case Vi_4D_token:Vi_4D_handler() ; break; 


case V2_token:V2_handler() ; break; 


Tf, case V2_2D_token:V2_2D_handler() ; break; 
Vee case V2_3D_token:V2_3D_handler() ; break; 
// case V2_4D_token:V2_4D_handler() ; break; 


case V3_token:V3_handler () ; break; 

case V3_2D_token:V3_2D_handler() ; break; 
V7 case V3_3D_token:V3_3D_handler () ; break; 
Vy case V3_4D_token:V3_4D_handler() ; break; 


case V4_token:V4_handler () ; break; 


A case V4_2D_token:V4_2D_handler() ; break; 
// case V4_3D_token: V4_3D_handler() ; break; 
V7 case V4_4D_token:V4_4D_handler() ; break; 


case V5_token:V5_handler () ; break; 

case V5_2D_token:V5_2D_ handler () ; break; 
case V5_3D_token:V5_3D_handler() ; break; 
case V5_4D_token:V5_4D_handler() ; break; 


protected void cancel_handler() { 
this. hide() ; 
this.dispose(); 
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//used to call the search engine 
//The cgi script dictates that the order be 1,2,5,3,4 


protected void search_handler() { 

Weights W = new Weights("DecisionNet Search Engine", 
"Please use this applet to specify your \n" 
+"preferences and objectives for the search algorithm. \n" 
+"Press ’Submit to Search Engine’ to launch your search. \n" 
+"This Applet is written in Java By LT Chris Corgnati.\n" 
+" Nas 
ConsumerID_Value,tObjectType_Value, Vi_Value,V2_Value, 
V5_Value,V3_Value,V4_Value, Protocol ,Database_Home, 
port ,Search_Engine_Loc,Default_Weight ,Default_C_Deg, 
Default_P_Deg,Default_S_Deg,ConsumerID_db_value, 
tObjectType_db_value, V1_cgi_label ,V2_cgi_label, 
V3_cgi_label,V4_cgi_label ,V5_cgi_label1l) ; 


W.resize(700,700) ; 
W.show(); 


this. hide() ; 
this.dispose() ; 


//used to call the registration cgi script 
public void submit_handler() { 
//resets the querystring 
»tring querystmmz: -— as 


//These varibles need to be passed in from the HTML page to the applet 
QueryString Q = new QueryString(ProviderID_db_value, 
ProviderID_Value) ; 
Q.add(TechID_db_value,TechID_Value) ; 
Q.add(TechName_db_value,TechName_Value) ; 
Q.add(tObjectType_db_value,tObjectType_Value) ; 


//These variables are user selections 

//The cgi script dictates that the order be 1,2,5,3,4 
Q.add(V1_cgi_label,V1_Value) ; 
Q.add(V2_cgi_label,V2_Value) ; 
Q.add(V5_cgi_label,V5_Value) ; 
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Q.add(V3. cgi_label,V3_Value) ; 
Q.add(V4_cgi_label ,V4_Value) ; 


//These varibles need to be passed in from the HTML page to the applet 
Q.add(tURL_db_value,tURL_Value) ; 
Q.add(ExcInd_db_value,ExcInd_Value) ; 

Q.add(Purpose_db_value, Purpose_Value) ; 
Q.add(Comments_db_value ,Comments_Value) ; 


//sets local string to return of QueryString method 
querystring = Q.query; 


//attempt to establish a connection 
eave 

Message_Field.setText ("Establishing a Network Connection") ; 
URL u = new URL(Protocol ,Database_Home, port ,cgi_regteca) ; 
URLConnection connection = u.openConnection() ; 
connection.setDoOutput (true) ; 
connection.setDoInput (true) ; 
connection.setAllowUserInteraction(false) ; 


//send data to cgi program 

DataQutputStream dos = new DataQutputStream 
(connection. getOutputStream()) ; 

dos.writeBytes(querystring) ; 

dos.close(); 


try { 
String thasLine; 
String results = (" "); 


DataInputStream DIS = new DatalInputStream 
(connection. getInputStream()) ; 
while ((thisLine = DIS.readLine()) != null) { 
results = results + thisLine; 
| 
DIS e@lose (= 


//Open Dialog to display registration results 

Frame £4 = new Frame(); 

Reg_Complete D = new Reg _ Complete 
(f4,"DecisionNet Registration Results", 
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"Registration is Complete. \n" 
+"Thank you for using DecisionNet. \n" 
+"Press ’Return’ to go back to DecisionNet. \n" 


an \n" 
+4 Ne! . 
"Return to DecisionNet") ; 

D.show() ; 


DeresizeGe00e25O)e 
this-.hide(); 
this.dispose() ; 


Message_Field.setText ("Search Complete") ; 


//catch any exceptions 

catch (MalformedURLException e) { 
Message_Field.setText (e.toString()); 

} 


catch (IOException e) { 
Message_Field.setText (e.toString()); 


} 


catch (NullPointerException e) { 
Message_Field.setText(e.toString()) ; 
} 
} 


//catch any exceptions 
catch (MalformedURLException e) { 

Message_Field.setText(e.toString()) ; 

Frame £4 = new Frame(); 

Reg_ Complete D = new Reg_Complete 
(f4,"DecisionNet Registration Results", 
"Registration Failed(MalformedURLException). \n" 
+"If this continues, please contact DecisionNet. \n" 
+"Press the ’Return’ button to go back to DecisionNet. \n" 


+N \n" 
+4 \n" : 
"Return to DecisionNet") ; 

D.show() ; 


D.resize (300,250); 
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this. hide(); 
this.dispose() ; 
} 


catch (IOException e) { 

Message_Field.setText(e.toString()); 

Frame £4 = new Frame() ; 

Reg_Complete D = new Reg_Complete 
(f4,"DecisionNet Registration Results", 
"Registration Failed(IOException). \n" 
+"If this continues, please contact DecisionNet. \n" 
+"Press the ’Return’ button to go back to DecisionNet. \n" 


+" \n" 
a NE , 
"Return to DecisionNet") ; 

D.show(); 


D.resize (300, 250) ; 
this. hide(); 
this .dispose() ; 


i; 


catch (NullPointerException e) { 
Message_Field.setText(e.toString()); 
Frame £4 = new Frame(); 
Reg_Complete D = new Reg_Complete 
(f4,"DecisionNet Registration Results", 
"Registration Failed(NullPointerException). \n" 
+"If this continues, please contact DecisionNet. \n" 
+"Press the ’Return’ button to go back to DecisionNet. \n" 


4H \n" 
o ane 
"Return to DecisionNet") ; 

D.show(); 


D.resize (300, 250) ; 
this.hide(); 
this.dispose() ; 


protected void Vi_button_handler () { 
Current_Field.setText(V1_Label) ; 


me 


List_Token = 111; 
button_handler(V1i_Label1) ; 


protected void Vi_handler () { 
Level_2.clear() ; Level@s clgan© Wer-Im4 clear QO 
Vi_Field.setText (Level_1.getSelectedItem()) ; 
V1_2D_Field.setText("") ;Vi_3D_Field.setText("'") ; 
Vi_4D_Field.setText("") ;Vi_Value=Level_1i.getSelectedItem() ; 
vi level_handler (Protocol ,Data_File_Home, Tax_L2,Level_1,Level_2); 


| | ~a-n nnn nnn nn nanan nn nnn nnn nnn nn nnn nnn nnn nnn nnn 


// for future expansion to three dimensions of V1 type variable 
// protected void V1_2D_handler () { 


V Level_3.clear() ;Level_4.clear() ; 

// Vi_2D_Field.setText (Level_2.getSelectedItem()) ; 

// Vi_3D_Field.setText("") ;Vi_4D_Field.setText(""); 

Ve Vi_Value=Level_2.getSelectedItem() ; 

ey level_handler (Protocol ,Data_File_Home,Tax_L3,Level_1,Level_2) ; 
ij 

| [ern n nn Se — a ee 


// for future expansion to four dimensions of V1 type variable 
// protected void V1i_3D_handler () { 


a Level_4.clear(); 

Vy Vi_3D_Field.setText (Level_3.getSelectedItem()) ; 

Wi V1 4D Field. setters C!s 

i Vi_Value=Level_3.getSelectedItem() ; 

V7 level_handler (Protocol ,Data_File_Home, Tax_L4,Level_1,Level_2) ; 
fie _} 

| / -72 3 ge ST ee ee a oe 


// for future expansion to four dimensions of V1 type variable 
// protected void Vi_4D_handler () { 


// V1_4D_Field.setText (Level_4.getSelectedItem()) ; 

Wak V1_Value=Level_4.getSelectedItem() ; 

Ge 

| [--7 nee SSS Se 5 SS Se - 7 eee tee ae 
[ [-ssase3SsSS=S558 ee ee ee 


protected void V2_button_handler () { 
Current_Field.setText(V2_Label) ; 
List_Token = 222; 
button_handler(V2_Labe1) ; 
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// 


// 
Ve 
Ve 
// 
i, 
// 
// 
We 
Te 


a 
// 
// 
Li 
// 
Hi 
Le 
ha 


i, 
// 
Hi 
// 


protected void V2_handler () { 
Level_2achean@skeneclmSncheam® :lévelm4 Velhessa@ 
V2_Field.setText (Level_1.getSelectedItem()) ; 
Vi2e2D shed. set T easteiieV 2esDamielidasetText Ci 
V2_4D_Field.setText("") ;V2_Value=Level_1.getSelectedItem() ; 
level_handler (Protocol ,Data_File_Home,Tax_L2,Level_1,Level_2); 


for future expansion to three dimensions of V2 area variable 
protected void V2_2D_handler () { 
Level_3.clear() ;Level_4.clear() ; 
V2_2D_Field.setText (Level_2.getSelectedItem()); 
V2_3D_Field.setText("") ;V2_4D_Field.setText(""); 
tV2Area_Value=Level_2.getSelectedItem() ; 
level_handler (Protocol , Data_File_Home,Tax_L3,Level_1i,Level_2); 


for future expansion to four dimensions of V2 area variable 
protected void V2_3D_handler () { 
Level_4.clear() ; 
V2_3D_Field.setText (Level_3. getSelectedItem()) ; 
V2_4D_Field.setText(""); 
tV2Area_Value=Level_3.getSelectedItem() ; 
level_handler (Protocol ,Data_File_Home,Tax_L4,Level_1,Level_2); 
} 
for future expansion to four dimensions of V2 area variable 
protected void V2_4D_handler () { 
V2_4D_Field.setText (Level_4.getSelectedItem()) ; 
tV2Area_Value=Level_4.getSelectedItem() ; 


protected void V3_button_handler () { 
Current_Field.setText(V3_Label) ; 
List_Token = 333; 
button_handler(V3_Label) ; 


ee ee ee ee ce ee ee ee es es ce ww ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee we 


protected void V3_handler () { 


ao 


(Levells2. clean() ) :- Vewel_3.clear@) sWerel 42clleart)- 
V3_Field.setText (Level_1.getSelectedItem()) ; 
V3_2D_Field.setText("") ;V3_3D_Field.setText(""); 
V3_4D_Field.setText("") ; V3_Value=Level_1.getSelectedItem() ; 
level_handler (Protocol , Data_File_Home, Tax_L2,Level_1,Level_2) ; 


// for future expansion to three dimensions of V3 type variable 
protected void V3_2D_handler () { 
Level_3.clear() ;Level_4.clear() ; 
V3_2D_Field.setText (Level_2.getSelectedItem()); 
V3. 3DsFieldesetText("" eV2u4Dekucldeseadexme C™”)- 
V3_Value=Level_2.getSelectedItem() ; 
level_handler (Protocol,Data_File_Home,Tax_L3,Level_2,Level_3); 


// for future expansion to four dimensions of V3 type variable 
// protected void V3_3D_handler () { 


yy, Level_4.clear() ; 

ve V3_3D_Field.setText (Level_3.getSelectedItem() ); 

// V3_4D_Field.setText("") ; V3_Value=Level_3.getSelectedItem() ; 

ey. level_handler (Protocol ,Data_File_Home, Tax_L4,Level_3,Level_4) ; 
1) a 

| | ------—==--- -- > SS ee eee ee 


// for future expansion to four dimensions of V3 type variable 
// protected void V3_4D_handler () { 


// V3_4D_Field.setText (Level_4.getSelectedItem()); 

ye V3_Value=Level_4.getSelectedItem() ; 

(es 

| |------- =~ ---- Sg gg ee See ee a ee > 
| /--s- ase ae oo eee ee 


protected void V4_button_handler () { 
Current_Field.setText(V4_Label1) ; 
List_Token = 444; 
button_handler(V4_Label1) ; 


protected void V4_handler () { 
(Level_2.clear());Level_3.clear();Level_4.clear() ; 
V4_Field.setText (Level_1.getSelectedItem()) ; 
V4_2D_Field.setText("") ;V4_3D_Field.setText(""); 
V4_4D_Field.setText("") ;V4_Value=Level_1.getSelectedItem() ; 
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// 
Lh 
// 
Th 
// 


level_handler (Protocol ,Data_File_Home , Tax_L2,Level_1,Level_2) ; 


— > op eee cee ee a ee ee ee ee ee ee ee ee ee ce ec ee ee ee ec es es ce ce es es ee ee ee ee es ee ee 


protected void V4_2D_handler () { 
Level_3.clear() ;Level_4.clear(); 
V4_2D_Field.setText (Level_2.getSelectedItem()); 
V4_3D_Field.setText("") ;V4_4D_Field.setText(""); 
V4_Value=Level_2.getSelectedItem() ; 
level_handler (Protocol,Data_File_Home , Tax_L3,Level_2,Level_3) ; 


—_en eee ee ae ee es ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee ee es ee ee ee 


for future expansion to four dimensions of V4 type variable 
protected void V4_3D_handler () { 
Level_4.clear(); 
V4_3D_Field.setText (Level_3.getSelectedItem()); 
V4_4D_Field.setText("") ;V4_Value=Level_3.getSelectedItem() ; 
level_handler (Protocol ,Data_File_Home , Tax_L4,Level_3,Level_4) ; 


ee ee ee ee ee ee ee ee ee ee ee ee ee > ee ee ee oe a a a ee ee ee ee ee > > > > ee ee ee ee ee ee ee ee > ee ee ee ee 2 eo 2 6 2 2 2 a= a= == == 


for future expansion to four dimensions of V4 type variable 
protected void V4_4D_handler () { 
V4_4D_Field.setText (Level_4.getSelectedItem()) ; 
V4_Value=Level_4.getSelectedItem() ; 


ee ws ce ce cc cr cc cm crm cr cr me a ae SS SS Se SS 


protected void V5_button_handler () { 
Current_Field.setText (V5_Label1) ; 
List_Token = 555; 
button_handler(V5_Label) ; 


mmm cr cr ew tet ete cit eit eee ee ee ee ee ss ce ee ee mm ee a ee ee 


protected void V5_handler () { 
(Level_2.clear()); (Level_3.clear());(Level_4.clear()); 
V5_Field.setText(Level_1.getSelectedItem()) ; 
V5_2D_Field.setText("") ;V5_3D_Field.setText(""); 
V5_4D_Field.setText(""); 
V5_Value=Level_i.getSelectedItem() ; 
level_handler (Protocol ,Data_File_Home, Tax_L2,Level_1,Level_2):; 


— ce ec cs ce cm cm me ee ec em ee ee ee ce 


protected void V5_2D_handler () { 
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(Level_3.clear()); (Level_4.clear()); 

V5_2D_Field.setText (Level_2.getSelectedItem()) ; 
V5_3D_Field.setText("") ;V5_4D_Field.setText("") ; 
V5_Value=Level_2.getSelectedItem() ; 

level_handler (Protocol ,Data_File_Home,Tax_L3,Level_2,Level_3); 


protected void V5_3D_handler () { 
(Level_4.clear()); 
V5_3D_Field.setText (Level_3.getSelectedItem() ); 
V5_4D_Field.setText("") ; V5_Value=Level_3.getSelectedItem() ; 
level_handler (Protocol ,Data_File_Home,Tax_L4,Level_3,Level_4): 


protected void V5_4D_handler () { 
V5_4D_Field.setText (Level_4.getSelectedItem() ); 
V5_Value=Level_4.getSelectedItem() ; 


protected void button_handler (String var_name) { 

Level 1. cleam@™ bemolil? Fakoan@k 

Level_3.clear() ;Level_4.clear() ; 

try 
URL url = new URL(Protocol ,Data_File_Home,Tax_L1) ; 
URLConnection connection = url.openConnection() ; 
input = connection.getInputStream() ; 
Grep g = new Grep(var_name,Level_i,input) ; 

} 

catch (MalformedURLException e) { 
Current_Field.setText ("URL Exception") ; 

} 

catch (IOException i) { 
Current_Field.setText ("I/O Exception") ; 


protected void level_handler(String Protocol, 
String Data_File_Home,String FileLocation, 
List Current,List Target) { 
trey { 
URL url = new URL(Protocol ,Data_File_Home ,FileLocation) ; 
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URLConnection connection = url.openConnection() ; 
input = connection.getInputStream() ; 
Grep g = new Grep(Current.getSelectedItem() , Target, input) ; 
i 
catch (MalformedURLException e) { 
Current_Field.setText("URL Exception") ; 
i 
catch (I0Exception i) { 
Current_Field.setText("I/0 Exception") ; 


//These constrain functions are used to layout the components both 
//within thier panels and the panels within the frame. 
//(from Java in Nutshell) 
public void constrain (Container container,Component component, 
int grid. x,int grid_y,int grid_width,int grid_height, 
int fill,int anchor,double weight_x,double weight_y, 
iieeuopsInu left,1nt bottom.int reeht) { 


GridBagConstraints c = new GridBagConstraints() ; 
Caplan SrIdex;C.pridy = prid_y; 
c.gridwidth = grid_width;c.gridheight = grid_height; 
c.fill = fill;c.anchor = anchor; 
c.welghtx = weight_x;c.weighty = weight_y; 
if (top + bottom + left + right > 0) 
c.insets = new Insets(top,left,bottom, right) ; 

((GridBagLayout) container.getLayout()).setConstraints 

(component ,c) ; 
container.add(component) ; 


I; 

/: | a SSSR SSS Sa SRS aera ee ae oo” — san 
public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height) { 

constrain (container ,component ,grid_x,grid_y,grid_width, 
grid_height ,GridBagConstraints.NONE, 
GridBagConstraints .NORTHWEST,0.0,0.0,0,0,0,0); 
i 
ff nee eee eee 


public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
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int top,int,lefteameebocconmmitericnt) 4 

constrain (container, component, grid_x,grid_y,grid_width, 
grid_height,GridBagConstraints.NONE, 

GridBagConstraints .NORTHWEST,0.0,0.0,top, left, bottom, right) ; 
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APPENDIX H. WEIGHTS 


// The Weights class is the interface for both consumer search and 

// producer registration 

ye, 

// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
ei 


// Last modified: Version i.i 
// 1300 29 July 1997 
| | naan nnn nnn nnn nnn nnn nnn nnn nnn nnn nn nnn nn nnn nnn nnn nnn nnn 


import java.awt.*; 
import java.i1o.*; 
import java.net.*; 


public class Weights extends Frame { 


//Flags that pass control internal to this object 
Button Search,Cancel; 


Label Problem_Label,Functional_Label,Organization_Label, 
Industry_Label ,Solution_Label,Weight_Col,Child_Col, 
Parent_Col,Sibling Col; 


MultiLineLabel Narrative,Legend; 


TextField Problem_Weight,Problem_C_Deg, 
Problem_P_Deg,Problem_S_Deg ; 
TextField Functional_Weight,Functional_C_Deg, 
Functional_P_Deg,Functional_S_Deg; 
TextField Organization_Weight ,Organization_C_Deg, 
Organization_P_Deg,Organization_S_Deg; 
TextField Industry_Weight , Industry_C_Deg, 
Industry_P_Deg, Industry_S_Deg; 
TextField Solution_Weight ,Solution_C_Deg, 


Solution_P_Deg,Solution_S_Deg; 


TextField Message_Field,; 

String Default_Weight = new String(Default_Weight_Param) ; 
Strime Default_C_Deg = new String(Default_C_Deg_ Param) ; 
String Default_P_Deg = new String(Default_P_Deg Param) ; 
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String Default_S_Deg = new String(Default_S_Deg Param) ; 
GridBagLayout gridbag = new GridBagLayout () ; 


//Nariables used to create the querystring 
String ConsumerID = new String(ConsumerID_db) ; 
String tObjectType = new String(tObjectType_db) ; 
String tProblemArea = new String(tProblemArea_db) ; 
String tFunctionalArea = new String(tFunctionalArea_db) ; 
String tSolutionMethod = new String(tSolutionMethod_db) ; 
String tIndType = new String(tIndType_db) ; 
String tOrgType = new String(tOrgType_db) ; 


//Nariables pass<1 from taxonomy object-will be submitted to search 
String ConsumerID_Value = new String (ConsumerID_Param) ; 
String tObjectType_Value = new String(tObjectType_Param) ; 
String tProblemArea_Value = new String(tProblemArea_Param) ; 
String tFunctionalArea_Value = new String(tFunctionalArea_Param) ; 
String tSolutionMethod_Value = new String(tSolutionMethod_Param) ; 
String tIndType_Value = new String(tIndType_Param) ; 
String tOrgType_Value = new String(tOrgType_Param) ; 


//Network variables to connect to CGI programs 
String Protocol = new String(Protocol); 
String dneti = new String(DB_URL) ; 
Inepemr = Ort ; 
// cgi_indexed is the home of the delphi search engine script 
String cgi_indexed = new String(Search_Engine_Loc) ; 


// Constuctor Code-instances of taxonomy must call it with this info 
public Weights(String title,String message,String ConsumerID_Paran, 

string tObjectType_Param,String tProblemArea_Paran, 
String tFunctionalArea_Param,String tSolutionMethod_Paran, 
String tIndType_Param,String tOrgType_Param,String Protocol, 
String DB_URL,int Port,String Search_Engine_Loc, 
String Default_Weight_Param,String Default_C_Deg_Paran, 
string Default_P_Deg_Param,String Default_S_Deg_Paran, 
String ConsumerID_db,String tObjectType_db, 
String tProblemArea_db,String tFunctionalArea_db, 
String tSolutionMethod_db,String tIndType_db, 
String tOrgType_db) { 
super (title) ; 
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// Panel 1-Instructions 
Search = new Button ("Submit to Search Engine") ; 
Cancel = new Button (" Return to DecisionNet ">: 


Message_Field = new TextField(30) ; 
Message_Field.setEditable(false) ; 


Panel pi = new Panel(); 
pi.setLayout (gridbag) ; 


constrain(p1,Search,0,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p1,Message_Field,1,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p1,Cancel,2,0,1,1,GridBagConstraints. BOTH, 
GridBagConstraints.CENTERY0.0,070,151,1,1); 


// Panel 2-Instructions 
Narrative = new MultiLineLabel (message, 1) ; 


Panel p2 = new Panel(); 
p2.setLayout (gridbag) ; 


constrain(p2,Narrative,0,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,0,0,0,0); 


// Panel 3-Instructions 
Legend = new MultiLineLabel 
("VW = Variable Weight (must sum to 1.0) \n" 


+! re! 
+"CDM = Child Degradation Multiplier \n" 
+"PDM = Parent Degradation Multiplier \n" 


+"SDM = Sibling Degradation Multiplier \n" 

ce Ne 

+"Default Values are shown. Advanced users may define \n" 
+"custom values here. Degradation Multipliers must be in \n" 
+"the interval [0,1]. Higher values indicate a stronger 
preference \n" 

+"for the selected item only. Lower values allow the search 
tcann 

+"return more possible answers which may have a lower 
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relevancy.",1); 


Panel p3 = new Panel(); 
p3.setLayout (gridbag) ; 


constrain(p3,Legend,0,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,0,0,0,0); 


// Panel 3-Selection Display 


Weight_Col = new Label("VW") ; 
Child_Col = new Label("CDM"); 
Parent_Col = new Label("PDM") ; 
Sibling_Col = new Label("SDM"); 


Problem_Label = new Label("Problem Area"); 
Functional_Label = new Label("Functional Area"); 
Industry_Label = new Label("Industry Type"); 
Organization_Label = new Label("Organization Type") ; 
Solution_Label = new Label("Solution Area"); 


Problem_Weight = new TextField(Default_Weight ,5); 
Problem_Weight .setEditable(true) ; 

Problem_C_Deg = new TextField(Default_C_Deg,5) ; 
Problem_C_Deg.setEditable(true) ; , 

Problem_P_Deg = new TextField(Default_P_Deg,5) ; 
Problem_P_Deg.setEditable(true) ; 

Problem_S_Deg = new TextField(Default_S_Deg,5) ; 
Problem_S_Deg.setEditable (true) ; 


Functional_Weight = new TextField(Default_Weight,5) ; 
Functional_Weight.setEditable(true) ; 
Functional_C_Deg = new TextField(Default_C_Deg,5); 
Functional_C_Deg.setEditable(true) ; 
Functional_P_Deg = new TextField(Default_P_Deg,5) ; 
Functional_P_Deg.setEditable(true) ; 
Functional_S_Deg = new TextField(Default_S_Deg,5); 
Functional_S_Deg.setEditable(true) ; 


Industry_Weight = new TextField(Default_Weight,5); 


Industry_Weight.setEditable(true) ; 
Industry_C_Deg = new TextField(Default_C_Deg, 5) ; 
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Industry_C_Deg.setEditable(true) ; 
Industry_P_Deg = new TextField(Default_P_Deg,5); 

Industry_P_Deg.setEditable(true) ; 
Industry_S_Deg = new TextField(Default_S_Deg, 5); 

Industry_S_Deg.setEditable(true) ; 


Organization_Weight = new TextField(Default_Weight, 5) ; 
Organization_Weight.setEditable(true) ; 
Organization_C_Deg = new TextField(Default_C_Deg,5) ; 
Organization_C_Deg.setEditable(true) ; 
Organization_P_Deg = new TextField(Default_P_Deg,5) ; 
Organization_P_Deg.setEditable(true) ; 
Organization_S_Deg = new TextField(Default_S_Deg, 5) ; 
Organization_S_Deg.setEditable(true) ; 


Solution_Weight = new TextField(Default_Weight,5) ; 
Solution_Weight.setEditable(true) ; 
Solution_C_Deg = new TextField(Default_C_Deg, 5) ; 
Solution_C_Deg.setEditable (true) ; 
Solution_P_Deg = new TextField(Default_P_Deg,5); 
Solution_P_Deg.setEditable(true) ; 
Solution_S_Deg = new TextField (Default_S_Deg,5); 
Solution_S_Deg.setEditable(true) ; 


Panel p5 = new Panel(); 
p5.setLayout (gridbag) ; 


constrain(p5,Weight_Col,1,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(p5,Child_Col,2,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(p5,Parent_Col,3,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 
constrain(pS,Sibling_Col,4,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0O.0,0.0,1,1,1,1); 


constrain(p5,Problem_Label,0,1,1,1,GridBagConstraints .HORIZONTAL, 
GridBagConstraints.CENTER,0.O0y000 ,1, Dyipips 
constrain(p5,Functional_Label,0,2,1,1,GridBagConstraints.HORIZONTAL, 


GridBagConstraints®CENTER,0. OO. 0) ieee 
constrain(p5,Industry_Label,0,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
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constrain(p5,Organization_Label,0,4,1,1, 
GridBagConstraints.HORIZONTAL,GridBagConstraints.CENTER, 
0-0 OMG 1 1y 

constrain (p5,Solution_Label ,0,5,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 

constrain(p5,Problem_Weight ,1,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p5,Problem_C_Deg,2,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p5,Problem_P_Deg,3,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 

constrain(p5,Problem_S_Deg,4,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 


constrain(p5,Functional_Weight ,1,2,1,1, 
GridBagConstraints.HORIZONTAL,GridBagConstraints.CENTER, 
ORO2O 0) 1 wie 1) 


constrain(p5,Functional_C_Deg,2,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraintssCENTERRORO)0s0; 1 iis 

constrain (p5,Functional_P_Deg,3,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 

constrain(p5,Functional_S_Deg,4,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p5, Industry_Weight,1,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 

constrain(p5, Industry_C_Deg ,2,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p5, Industry_P_Deg ,3,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0O.0,0.0,1,1,1,1); 

constrain(p5, Industry_S_Deg,4,3,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 


constrain(p5,Organization_Weight,1,4,1,1, 
GridBagConstraints.HORIZONTAL,GridBagConstraints.CENTER, 
0207070 ,1, 1,17 

constrain(p5,Organization_C_Deg,2,4,1,1, 
GridBagConstraints.HORIZONTAL, GridBagConstraints.CENTER, 
OmOn OROe 1 , deel , We 

constrain(p5,Organization_P_Deg,3,4,1,1, 
GridBagConstraints. HORIZONTAL, GridBagConstraints.CENTER, 
OF 000 15 tegke 1) 


90 


constrain(p5,Organization_S_Deg,4,4,1,1, 
GridBagConstraints .HORIZONTAL,GridBagConstraints.CENTER, 
05 0507051,.14 la 


constrain(p5,Solution_Weight,1,5,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p5,Solution_C_Deg,2,5,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p5,Solution_P_Deg,3,5,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain(p5,Solution_S_Deg,4,5,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,O.0,0.0,1,1,1,1); 


cd 


// Add panels to the top level window and arrange the panels 
this.setLayout (gridbag) ; 


constrain (this,p1,0,0,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain (this,p2,0,1,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,1,1,1,1); 
constrain (this,p3,0,2,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4); 
constrain (this,p5,0,4,1,1,GridBagConstraints.NONE, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4) ; 


public boolean action(Event event,Object arg) { 
if (event .target instanceof Button) { 
if (event.target == Cancel) { 
this.hide() ; 
this .dispose() ; 
F 


if (event.target == Search) { 
//resets the querystring 
String querystring = " "; 


//These varibles need to be passed in from the HTML 
//page to the applet 

QueryString Q = new QueryString(ConsumerID, 
ConsumerID_Value) ; 

Q.add(tObjectType, tO0bjectType_Value) ; 


oil 


//These variables are user selections 
.add(tProblemArea, tProblemArea_Value) ; 
.add(tFunctionalArea,tFunctionalArea_Value) ; 
.add(tSolutionMethod, tSolutionMethod_Value) ; 
.add(tIndType,tIndType_Value) ; 
.add(tOrgType, tOrgType_Value) ; 


OOO © 


String PW = new String(Problem_Weight .getText()); 
Q.add("Problem_Weight" , PW) ; 
String PCD = new String(Problem_C_Deg.getText()); 
Q.add("Problem_C_Deg" , PCD) ; 
String PPD = new String(Problem_P_Deg.getText()) ; 
Q.add("Problem_P_Deg" , PPD) ; 
String PSD = new String(Problem_S_Deg.getText()) ; 
Q.add("Problem_S_Deg",PSD) ; 


String FW = new String(Functional_Weight.getText()); 
Q.add("Functional_Weight" , FW) ; 
String FCD = new String(Functional_C_Deg.getText()) ; 
Q.add("Functional_C_Deg", FCD) ; 
String FPD = new String(Functional_P_Deg.getText()) ; 
Q.add("Functional_P_Deg",FPD) ; 
String FSD = new String(Functional_S_Deg.getText()) ; 
Q.add("Functional_S_Deg", FSD) ; 


String IW = new String(Industry_Weight.getText()) ; 
Q.add("Industry_Weight", IW) ; 
String ICD = new String(Industry_C_Deg.getText()) ; 
Q.add("Industry_C_Deg" , ICD) ; 
String IPD = new String(Industry_P_Deg.getText()) ; 
Q.add("Industry_P_Deg" , IPD) ; 
String ISD = new String(Industry_S_Deg.getText()) ; 
Q.add("Industry_S_Deg" , ISD) ; 


String OW = new String(Organization_Weight.getText()); 
Q.add("Organization_Weight" , OW) ; 
String OCD = new String(Organization_C_Deg.getText()); 
Q.add("Organization_C_Deg" , OCD) ; 
String OPD = new String(Organization_P_Deg.getText()) ; 
Q.add("Organization_P_Deg", OPD) ; 
String OSD = new String(Organization_S_Deg.getText()); 


92 


Q.add("Organization_S_Deg", OSD) ; 


String SW = new String(Solution_Weight.getText()) ; 
Q.add("Solution_Weight", SW) ; 
String SCD = new String(Solution_C_Deg.getText()); 
Q.add("Solution_C_Deg",SCD) ; 
String SPD = new String(Solution_P_Deg. getText()); 
Q.add("Solution_P_Deg", SPD) ; 
String SSD = new String(Solution_S_Deg.getText()); 
Q.add("Solution_S_Deg",SSD) ; 


//sets local string to return of QueryString method 
querystring = Q.query; 


//attempt to establish a connection 

Cie 

Message_Field.setText("Establishing Network 
Connection... >): 

URL u = new URL(Protocol,dneti1,port,cgi_indexed) ; 
URLConnection connection = u.openConnection(); 
Message_Field.setText("Searching DecisionNet..."); 
connection.setDoOutput (true) ; 
connection.setDoInput (true) ; 
connection.setAllowUserInteraction(false) ; 


//send data to cgi program 

DataQOutputStream dos = new DataQutputStream 
(connection. getOutputStream()) ; 
dos.writeBytes (querystring) ; 

dos.close(); 


//read in CGI response (string of text) 
cry 

String thisLine; 

String results = (""); 


DataInputStream DIS = new DatalnputStream 
(connection. getInputStream()) ; 
while ((thisLine = DIS.readLine()) != null) 
results = results + thisLine; 
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DIS .eltese(); 
Message_Field.setText("Search Complete") ; 


//call results display screen which will parse the 
//input stream and show it 

Frame £4 = new Frame(); 

Search_Results S = new Search_Results 
(£4,"DecisionNet Search Results", 

"Results of your search. \n" 

+"Thank you for using DecisionNet. \n" 

+"Press the ’Return’ button to go back to 
DecisionNet. \n" 


ea W An" 
4M Ne ; 
"Return to DecisionNet",results) ; 

S.show(; 


Stes i Zei@n00), 700) : 
this.hide(); 
this.dispose() ; 

} 


//catch any exceptions 
catch (MalformedURLException e) { 


Message_Field.setText(e.toString()) ; 
} 


catch (IOException e) { 


Message_Field.setText(e.toString()) ; 
} 


catch (NullPointerException e) { 
Message_Field.setText(e.toString()) ; 


} 


//catch any exceptions 
catch (MalformedURLException e) { 
Message_Field.setText(e.toString()); 
Frame f4 = new Frame(); 
Reg_Complete D = new Reg_Complete 
(£4,"DecisionNet Search Results", 
"Search Engine Failed(MalformedURLException). \n" 
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+"If this continues, please contact DecisionNet. \n" 
+"Press the ’Return’ button to go back to 
DecisionNet. \n" 


eo \n" 
+" \n", 
"Return to DecisionNet"); 

D.show() ; 


D.resize(300, 250): 
this. hide(); 
this .dispose() ; 


a 


catch (IOException e) { 

Message_Field.setText ("Connection Failed") ; 

Frame £4 = new Frame(); 

Reg_Complete D = new Reg Complete 

(f4,"DecisionNet Search Results", 
"Search Engine Failed(I0Exception). \n" 
+"If this continues, please contact DecisionNet. \n" 
+"Press the ’Return’ button to go back to 
DecisionNet. \n" 


+" ae 
+" Neri 
"Return to DecisionNet"); 

D.show(); 


D.resize(300, 250) ; 
this. hide(); 
this.dispose() ; 

} 


catch (NullPointerException e) { 

Message_Field.setText(e.toString()) ; 

Frame £4 = new Frame() ; 

Reg_Complete D = new Reg Complete 
(£4,"DecisionNet Search Results", 
"Search Engine Failed(NullPointerException). \n" 
+"If this continues, please contact DecisionNet. \n" 
+"Press the ’Return’ button to go back to 
DecisionNet. \n" 
af 1 Yn" 
+" \n", 
"Return to DecisionNet") ; 
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D.show() ; 
D.resize(300, 250) ; 
this. hide(); 
this.dispose() ; 


i 
ii 
return true; 
} 


else return false; 


//These constrain functions are used to layout the components both 
//within thier panels and the panels within the frame. 
//(from Java in Nutshell) 
public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
int fill,int anchor,double weight_x,double weight_y, 
int top,int left,int bottom,int right) { 


GridBagConstraints c = new GridBagConstraints() ; 
€.gridx = grid=x;c gridy — Gay 
c.gridwidth = grid_width;c.gridheight = grid_height; 
c.fill = fill;c.aneweér—Fareicr,; 
c.welghtx = weight_x;c.weighty = weight_y; 
if (top + bottom + left + righueeme) 

c.insets = new Insets(top, left, bottom, right) ; 
((GridBagLayout) container.getLayout()).setConstraints 

(component ,c) ; 

container .add(component) ; 


public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height) { 
constrain (container ,component,grid_x,grid_y,grid_width, 
grid_height ,GridBagConstraints.NONE, 
GridBagConstraints .NORTHWEST,0.0,0.0,0,0,0,0); 


public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
int top,int left,int bottom,int right) { 
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constrain (container,component,grid_x,grid_y,grid_width, 
grid_height ,GridBagConstraints.NONE, 
GridBagConstraints.NORTHWEST,0.0,0.0,top,left, bottom, right) ; 


oa 





APPENDIX I. SEARCH RESULTS 


// The Search Results class is used to display the data returned from 
// the cgi script search engine 


V7 


// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
yf 
// Last modified: 1400 29 July 1997 Version 1.0 


import java.awt.*; 
iipert Java. 10e*; 
import java. ubal. + 


public class Search_Results extends Dialog { 


// Control variables are internal to this object 
private static final int Cancel = 1; 


protected Button cancel; 
protected MultiLineLabel label; 
protected TextArea display; 


protected String line; 
protected String[] lines; 


protected int num_lines; 

GridBagLayout gridbag = new GridBagLayout() ; 

// Constructor code 

public Search_Results(Frame f,String title,String message, 
String Cancel_label,String results) 

{ 


super (f, "DecisionNet" ,false) ; 
this.setLayout(new BorderLayout (40,60)) ; 


// Creation and layout of GUI components 
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Panel pi = new Panel(); 
p1.setLayout (gridbag) ; 
label = new MultiLineLabel (message, 1) ; 


constrain(p1,label,0,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4); 


Panel p2 = new Panel(); 
p2.setLayout (gridbag) ; 
display = new TextArea(23,70) ; 


//this code parses the input stream by the character & 
//into an array of strings to be displayed 
StringTokenizer t = new StringTokenizer(results,"&") ; 
num_linesc = t.countTokens() ; 
lines = new String[num_lines] ; 
for(int i = 0;i < num_lines;it++) 
lines[i] = (t.nextToken()+" \n"); 
for(int i = 0;i < num_lines;it+)display.appendText (lines [i]) ; 


constrain(p2,display,0,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4) ; 


Panel p3 = new Panel(); 
p3.setLayout (gridbag) ; 
cancel=new Button (Cancel_label); 


constrain(p3,cancel,0,0,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4) ; 


this.show() ; 

// Arrange the panels 

this.setLayout (gridbag) ; 

// Add panels to the top level window 

constrain (this,p1,1,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENTER,0.0,0.0,3,3,3,3); 

constrain (this,p2,1,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,3,3,3,3); 

constrain (this,p3,1,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,3,3,3,3); 

} 
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// Event Handler 
public boolean action(Event e,Object arg) { 
if (e.target instanceof Button) { 

answer (Cancel) ; 

return true; 


i 
else return false; 
* 
area a= 50S ee eee eee 
protected void answer(int answer) { 
switch(arswer) { 
case Cancel:cancel () ;y break; 
} 
k 
aE a a 
protected void cancel() { 
this.hide() ; 
this .dispose() ; 
} 
+2 ee - = -  e 


//These constrain functions are used to layout the components both 
//within thier panels and the panels within the frame. 
//(from Java in Nutshell) 
public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
int fill,int anchor,double weight_x,double weight_y, 
int top,int left,int bottom,int right) { 


GridBagConstraints c = new GridBagConstraints() ; 
€.gridx = grid_x;c.pgridy”= prid7y; 
c.gridwidth = grid_width;c.gridheight = grid_height; 
c.fill = fill;c.anchor = anchor; 
c.weightx = weight_x;c.weighty = weight_y; 
jaéop + bottom leit + righty 9) 

c.insets = new Insets(top,left, bottom,right) ; 
((GridBagLayout) container. getLayout()).setConstraints 

(component, c) ; 

container .add (component) ; 


public void constrain (Container container,Component component, 
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int grid_x,int grid_y,int grid_width,int grid_height) { 


constrain (container,component ,grid_x,grid_y,grid_width, 
grid_height ,GridBagConstraints.NONE, 
GridBagConstraints.NORTHWEST ,0.0,0.0,0,0,0,0) ; 


public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
int top,int left,int bottom,int right) { 


constrain (container,component,grid_x,grid_y,grid_width, 


grid_height ,GridBagConstraints.NONE, 
GridBagC-nstraints .NORTHWEST,0.0,0.0,top,left,bottom,right) ; 
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APPENDIX J. REG COMPLETE 


// The Reg_Complete class is an class to display registration results 


H7. 


// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
an 
// Last modified: 1700 9 July 1997 Version 1.0 


import java.awt.*; 


public class Reg_Complete extends Dialog { 


// Control variables are internal to this object 
private static final int Cancel = 1; 


protected Button cancel; 
protected MultiLineLabel label; 
GridBagLayout gridbag = new GridBagLayout () ; 
// Constructor code 
public Reg_Complete(Frame f,String title,String message, 
String Cancel_label) 
‘ 
super (f,""DecisionNet", false) ; 
this.setLayout(new BorderLayout (20,20) ) ; 
// Creation and layout of GUI components 
Panel pi = new Panel(); 


pl.add(label = new MultiLineLabel(message,1)) ; 


Panel p2 = new Panel(); 
p2.setLayout (gridbag) ; 


cancel=new Button (Cancel_label); 


constrain(p2,cancel,1,2,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,4,4,4,4) ; 
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this.show(); 


// Arrange the panels 
this.setLayout (gridbag) ; 
// Add panels to the top level window 
constrain (this,p1,1,0,1,1,GridBagConstraints.BOTH, 
GridBagConstraints.CENMERRO. 0, ORO, 33 ,3H2) ; 
constrain (this,p2,1,1,1,1,GridBagConstraints.HORIZONTAL, 
GridBagConstraints.CENTER,0.0,0.0,3,3,3,3); 


// Event Handler 
public boolean action(Event e,Object arg) { 
if (e.target instanceof Button) { 
answer (Cancel) ; 
return true; 
} 


else return false; 


protected void answer(int answer) { 
switch(answer) { 
case Cancel -:cancel © : break; 


iF 
} 
| ee Sa eS nas 
protected void cancel() { 
this hideQ) ; 
this.dispose() ; 
} 
| | ee Te Ee 


public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
int fill,int anchor,double weight_x,double weight_y, 
int top,int left,int bottom,int right) { 


GridBagConstraints c = new GridBagConstraints() ; 
c.gridx = grid_x;c.gridy = grid_y; 

c.gridwidth = grid_width;c.gridheight = grid_height; 
c.fill = fill;c.anchor = anchor; 

c.weightx = weight_x;c.weighty = weight_y; 

if (top + bottom + left + right > 0) 
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c.insets = new Insets(top,left,bottom, right) ; 
((GridBagLayout) container. getLayout()). 
setConstraints (component, c) ; 
container .add(component) ; 


} 

/ |~----------------------------------------- === === == === --------------- 
public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height) { 

constrain (container, component ,grid_x,grid_y,grid_width, 
grid_height ,GridBagConstraints.NONE, 
GridBagConstraints.NORTHWEST,0.0,0.0,0,0,0,0); 
I; 
one ee eee 
public void constrain (Container container,Component component, 
int grid_x,int grid_y,int grid_width,int grid_height, 
imvuecop,inc lert,int bottom,int right) 1 
constrain (container, component ,grid_x,grid_y,grid_width, 
grid_height ,GridBagConstraints.NONE, 
GridBagConstraints.NORTHWEST,0.0,0.0,top,left,bottom,right) ; 
} 
} 
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APPENDIX K. GREP 


// The Grep class is an class to identify lines from taxonomy.db 

// that contain a given string arguement 

ve 

// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
/e 

// Last modified: 1300 29 July 1997 Version 1.1 


import java.io.*; 
import java.awt.*; 


public class Grep { 
List level; 


public Grep(String args,List level,InputStream i) { 


rae 
DatalnputStream d = new DatalInputStream(i) ; 


GrepInputStream g = new GrepInputStream(d,args, level) ; 
String line = null; 
String display = null; 


do { 
//calls GrepInputStream 
line = g.readLine() ; 


//names in data files start at character 38 
display = line.substring (38) ; 


//display only values of the attribute in 
//appropriate list 
level.addItem(display) ; 
} 
while (line != null); 
g.close(); 
fi 


catch (I10Exception e) { 
level.addItem("unexpected error") ; 
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} 


finally { 
} 
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APPENDIX L. GREPINPUTSTREAM 


// The GrepInputStream class is an object to filter the taxonomy 

ee 

// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
i 

// Last modified: 1300 29 July 1997 Version 1.1 


import java.io.*; 
import java.awt.*; 


public class GrepInputStream extends FilterInputStream { 
String substring; 
DataInputStream in; 
List level; 


public GrepInputStream(DataInputStream in,String substring, 
List level){ 
super (in) ; 
this.in = in; 
this.substring = substring; 


public final String readLine() throws I0Exception { 
String line; 
dio { 
line = in.readLine(); 


i 

while ((line != null) && line.indexOf(substring) == -1); 
return line; 

} 
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APPENDIX M. QUERYSTRING 


// The QueryString class is an class to combine string values for 

// input to a CGI script. 

// 

// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
// 

// Last modified: 1400 30 June 1997 Version 1.0 


import java.net.URLEncoder; 


public class QueryString { 
String query; 


public QueryString(Object name,Object value) { 
query = URLEncoder.encode(name.toString()) + "=" + 


URLEncoder.encode(value.toString()); 
} 


public void add(Object name,Object value) { 
query += "&" + URLEncoder.encode(name.toString()) + "=" + 


URLEncoder.encode(value.toString()) ; 
} 


Publac String toStrimg@) { 
FeEURENeGUETY ; 


} 
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APPENDIX N. MULTILINELABEL 


// The MultiLineLabel class is an object to parse a long string into 
// smaller strings for display. Java doesn’t support a label greater 
// than one line. Borrowed from "Java in a Nutshell". 

// 

// Copyright by: LT Chris Corgnati for Thesis work with Prof Bhargava 
// 

// Last modified: 1300 29 July 1997 Version 1.1 


import java.awt.*; 
import java.util.*; 


public class MultiLineLabel extends Canvas { 
public static final int LEFT=0; 
public static final int CENTER=1 ; 
public static final int RIGHT=2; 
protected String[] lines; 
protected int num_lines; 
protected int margin_width; 
protected int margin_height ; 
protected int line_height; 
protected int line_ascent; 
protected int[(] line_widths; 
protected int max_width; 
protected int alignment=LEFT; 


protected void newLabel(String label) { 
StringTokenizer t=new StringTokenizer(label,"\n") ; 
num_lines = t.countTokens() ; 
lines = new String[num_lines] ; 
line_widths = new int(num_lines]; 
for(int i=0;i<num_lines; i++) lines [i]=t.nextToken() ; 


} 


protected void measure() { 
FontMetrics fm = this.getFontMetrics(this.getFont()); 
if (fm == null) return; 


line_height = fm.getHeight () ; 
line_ascent = fm.getAscent () ; 
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max_width = QO; 
for(int i=0;i<num_lines;it+) { 
line_widths([i] = fm.stringWidth(lines[i]); 
if (line_widths [i] >max_width)max_width=line_ widths [i] ; 


} 


public MultiLineLabel(String label,int margin_width, 
int margin_height,int alignment) { 


newLabel (label) ; 
this.margin_width = margin_width; 
this.margin_height = margin_height; 
this.alignment = alignment; 

} 

public MultiLineLabel (String label,int margin_width, 
int margin_height) { | 
this (label ,margin_width,margin_height, LEFT) ; 

} 

public MultiLineLabel(String label,int alignment) { 
this(label, 20,20, alignment) ; 

} 

public MultiLineLabel(String label) { 
this (label ,20,20,LEFT) ; 


} 

public void setLabel(String label) { 
newLabel (label) ; 
measure () ; 
repaint (); 


bs 
public void setFont(Font f) { 
super.setFont(f) ; 
measure () ; 
repaint (); 
} 
public void setForeground(Color c) { 
super.setForeground(c) ; 
repaint (); 
i 
public void setAlignment(int a) {alignment=a;repaint() ;} 
public void setMarginWidth(int mw) {margin_width=mw; repaint () ; } 
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public 
pully PVE 
public 
public 


public 


public 


void setMarginHeight(int mh) {margin_height=mh;repaint() ;} 
int getAlignment() {return alignment; } 

int getMarginWidth() {return margin_width;} 

int getMarginHeight() {return margin_height; } 


void addNotify() {super.addNotify() ;measure() ; } 


Dimension preferredSize() { 


return new Dimension(max_width + 2*margin_width, 


public 


num_lines * line_height + 2*margin_height) ; 


Dimension minimumSize() { 


return new Dimension(max_width ,num_lines*line_height) ; 


I, 


public 


void ,aint(Graphics g) { 


Mi ay 

Dimension d=this.size(); 

y=line_ascent + (d.height - num_lines * line_height)/2; 
for (int i = 0;i < num_lines;i++,y += line_height) { 


switch(alignment) { 
case LEFT: 
x=mMargin_width; break; 
case CENTER: 
default: 
x=(d.width — line widths lal) sopbreak 
case RIGHT: 
x=d.width - margin_width - line_widths[i] ; break; 
I 
g.drawString(lines[i],x,y); 
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APPENDIX O. INDEXED SEARCH 


unit Indexedi; {Technology Search Engine; created by Chris Corgnati. 
Last updated 23 Jul 97.} 


interface 


uses 
SysUtils, WinTypes, WinProcs, Messages, Classes, Graphics, Controls, 
Forms, Dialogs, DB, Cgidb, Cgi, DBTables; 


type 
TFormi = class(TForm) 

CGIEnvDatai: TCGIEnvData; 
BatchMovel: TBatchMove; 
Table1i: TTable; 
Query1i: TQuery; 
DataSourcei: TDataSource; 
BatchMove2: TBatchMove; 
Table3: TTable; 
DataSource2: TDataSource; 
Query2: TQuery; 
Table2: TTable; 
Query3: TQuery; 
DataSource3: TDataSource; 
Query4: TQuery; 
Table4: TTable; 
DataSource4: TDataSource; 
Table5: TTable; 
BatchMove3: TBatchMove; 
BatchMove4: TBatchMove; 
Table6: TTable; 
BatchMoved: TBatchMove; 
Table/7: TTab’e; 
Table8: TTable; 
procedure FormCreate(Sender: TObject) ; 


private 

{ Private declarations } 
public 

{ Public declarations } 
end; 


aa 


var 
Formi: TForm1; 


implementation 
{$R *.DFM} 
procedure TForm1.FormCreate(Sender: TObject) ; 


var 
N_R : smallint; {Number of Records in Technolo.db} 
N_T_R : smallint; {Number of Records in Search_Temp_2.db} 


{User selections passed to cgi from applet} 
Var_Value : array [0..4] of string; 
{database field names} 

Category : array [0..4] of string; 


{strings read from applet} 

Temp_Deg_Value : array [0..4,0..2] of string; 
{strings converted to float(single) } 
Deg_Value : array [0..4,0..2] of Single; 


{Values of variables from temp records} 
temp : array [0..50,0..4] of string; 
{holds provider info for display} 
intomomabGay 10-5002) otecthiug: 


{Record Variable Score} 

R_V_S : array [0..50,0..4] of Single; 
{Total Score for a given record} 

TS : array[0O..50] of Single; 


{strings read from applet} 
Temp_Weight : array [0..4] of string; 
{strings converted to float(single)} 
Weight : array [0..4] of Single; 


v : smallint; {variable counter} 
r : Smallint: {record counter} 
f : smallint; {field counter} 
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j : smallint; {loop counter} 


1 : smallint; 
k : smallint; 
ceo string; 
P: strings 


P_Temp : string; 
C_2_Temp : string; 
E 2. Temp. : strame ; 


{control flag for ’all’ selections} 

Var_All_Bool : array [0..50,0..4] of Boolean; 
{control flag for exact variable matches} 
Match_Bool : array [0..50,0..4] of Boolean; 
{control flag for child in taxonomy} 

child : array [0..50,0..4] of Boolean; 

{control flag for second level child in taxonomy} 
Child_Sec_Bool : array [0..50,0..4] of Boolean; 
{control flag for parent in taxonomy} 

parent : array [0..50,0..4] of Boolean; 

{control flag for second level parent in taxonomy} 
Parent_Sec_Bool : array [0..50,0..4] of Boolean; 
{control flag for sibling in taxonomy} 

sibling : array [0..50,0..4] of Boolean; 


test : string; 

begin 
{Standard cgi stuff} 
with CGIEnvDatal do 


begin 
websiteINIFilename := paramstr(1) ; 
application.onException := cgiErrorHandler; 
application. processMessages ; 
createStdout; 
sendPrologue; 


{find number of records} 
with Tableil do 
begin 
Tablel .open; 
N_R := Tableil.RecordCount ; 


led 


Tablei.close; 
end; 


{read in variables from applet and init arrays} 
{strings are converted to float or int where appropriate} 
for r := 0 to N_R do 
begin 
for v := 0 to 4 do 
begin 
child[r,v] := false; 
Child_Sec_Bool[r,v] := false; 
parent(r,v] := false; 
Parent_Sec_Bool{r,v] := false; 
sibling(r,v] := false; 
Var_All_Bool{r,v] := false: 
end; 
end; 


{used to generate the queries} 
C i= (ehile?); 
P := (’Parent’); 


{correspond to column headings in Technolo.db} 
Category[0] := (’tProblemArea’) ; 


Category[1] := (’tFunctionalArea’); 
Category[2] := (’tSolutionMethod’) ; 
Category[3] := (’tIndType’); 
Category[4] := (’tOrgType’) ; 


{user selected search criteria-from applet} 
Var_Value [0] GetSmallField(’tProblemArea’ ) ; 
Var_Value [1] GetSmallField(’tFunctionalArea’); 
Var_Value [2] GetSmallField(’tSolutionMethod’ ); 
Var_Value [3] GetSmallField(’tIndType’ ) ; 
Var_Value [4] GetSmallField(’tOrgType’ ) ; 


{user selected weights and degredation 
multipliers-from applet} 

Temp_Weight[0] := GetSmallField(’Problem_Weight’) ; 
Weight [0] := StrToFloat(Temp_Weight [0]); 
Temp_Deg_Value[0,0] := GetSmallField(’Problem_C_Deg’ ); 
Deg_Value[0,0] := StrToFloat(Temp_Deg_Value[0,0]); 
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Temp_Deg_Value[0,1] := GetSmallField(’Problem_P_Deg’) ; 
Deg_Value[0,1] := StrToFloat(Temp_Deg_Value[0,1]); 
Temp_Deg_Value[0,2] := GetSmallField(’Problem_S_Deg’) ; 
Deg_Value[0,2] := StrToFloat(Temp_Deg_Value[0,2]); 


Temp_Weight[1] := GetSmallField(’Functional_Weight’) ; 
Weight [1] := StrToFloat(Temp_Weight [1]) ; 
Temp_Deg_Value[1,0] := GetSmallField(’Functional_C_Deg’) ; 
Deg_Value[1,0] := StrToFloat(Temp_Deg_Value[1,0]); 
Temp_Deg_Value[1,1] := GetSmallField(’Functional_P_Deg’) ; 
Deg_Value[1,1] := StrToFloat(Temp_Deg_Value[1,1]); 
Temp_Deg_Value[1,2] := GetSmallField(’Functional_S_Deg’) ; 
Deg_Value[1,2] := StrToFloat(Temp_Deg Value[1,2]); 


Temp_weight(2] := GetSmallField(’Solution_Weight’) ; 
Weight(2] := StrToFloat(Temp_Weight [2] ); 
Temp_Deg_Value[2,0] := GetSmallField(’Solution_C_Deg’) ; 
Deg_Value[2,0] := StrToFloat(Temp_Deg_Value([2,0]); 
Temp_Deg_Value[2,1] := GetSmallField(’Solution_P_Deg’) ; 
Deg_Value[2,1] := StrToFloat(Temp_Deg_Value[2,1]); 
Temp_Deg_Value[2,2] := GetSmallField(’Solution_S_Deg’) ; 
Deg_Value[2,2] := StrToFloat (Temp_Deg Value[2,2]); 


Temp_Weight [3] GetSmallField(’ Industry_Weight’) ; 
Weight [3] := StrToFloat (Temp_Weight [3] ) ; 
Temp_Deg_Value[3,0] := GetSmallField(’Industry_C_Deg’) ; 
Deg_Value[3,0] := StrToFloat(Temp_Deg_ Value[3,0]); 
Temp_Deg_Value[3,1] := GetSmallField(’ Industry_P_Deg’) ; 
Deg_Value[3,1] := StrToFloat(Temp_Deg_Value[3, 1]); 
Temp_Deg_Value[3,2] := GetSmallField(’Industry_S_Deg’) ; 
Deg_Value[3,2] := StrToFloat(Temp_Deg_Value[3,2]) ; 


Temp_Weight([4] := GetSmallField(’Organization_Weight’) ; 
Weight [4] := StrToFloat (Temp_Weight [4] ) ; 
Temp_Deg_Value[4,0] := GetSmallField(’Organization_C_Deg’) ; 
Deg_Value[4,0] := StrToFloat(Temp_Deg_Value [4,0] ); 
Temp_Deg_Value[4,1] := GetSmallField(’Organization_P_Deg’) ; 
Deg_Value[4,1] := StrToFloat(Temp_Deg_Value[4,1]); 
Temp_Deg_Value[4,2] := GetSmallField(’Organization_S_Deg’) ; 
Deg_Value[4,2] := StrToFloat(Temp_Deg_Value[4,2]) ; 


{quick search for technologies that may be of interest 


LA 


send from Technolo.db to search_temp.db} 


{empty Search_Temp.db} 
with Table2 do 
begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Search_Temp’ ; 
TableType := ttParadox; 
EmptyTable; 
end; 


{select technologies that are potentially useful and send them 
to search_temp.db} 
with Queryl do 
begin 
for v := 0 to 4 do 
begin 
Query1.SQL.clear; 
Query1.SQL.add (’SELECT * FROM TECHNOLO’) ; 
Query1.SQL.add (’WHERE (’+ Category[v] +’ = "? 
+ Var_Value[v] + ’")”); 
Query1.SQL.add (’ORDER BY ProviderID,TechID’) ; 
BatchMovel.Execute; 
Queryi.close; 
end; 
end; 


{empty Search_Temp_2.db} 
with Table3 do 
begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Search_Temp_2’ ; 
TableType := ttParadox; 
EmptyTable; 
end; 


{remove duplicate records from Search_Temp.db and copy results 
to Search_Temp_2.db} 
with Table2 do 
begin 


ee 


Query2.SQL.clear ; 

Query2.SQL.add (’SELECT DISTINCT ProviderID,TechID, 
TechName, tProblemArea, tFunctionalArea, 
tSolutionMethod,tIndType,tOrgType ’); 

Query2.SQL.add (’ FROM Search_Temp ’); 

Query2.SQL.add (’ORDER BY ProviderID’); 

BatchMove2.Execute; 

Query2.close; 

end; 


{go through every record in Search_Temp_2.db and evaluate its value 
against the user selections. The relevence score should be sent to 
R_V_Str,v] for later use in calculating T_S} 


with Table3 do 
{find the number of records in Search_Temp_2.db} 
begin 
Table3.open; 
N_T_R := Table3.RecordCount ; 
Table3.close; 


{initialize arrays} 
C2 tem <= ( ’); 
P_2-temp := (” ”); 
fonene:—- 0 to Nolakrdo 


begin 
for v := 0 to 4 do 
begin 
R_Vagir, vy := (070); 
into: = (wae 
temp[r,v] := (’ ’); 
end; 
Tester) *= 300.0); 
end; 
end; 


with Table3 do 
begin 
Table3.open; 
Table3.First() ; 
{read in one record at a time to analyze the variables} 
for r := 0 to @NMT_R - 1) mo 
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begin 
{3 to 7 are actual field #s in db} 
temp[r,0] Table3.Fields [3] .AsString; 
temp[r,i] := Table3.Fields[4] .AsString; 
temp[r,2] := Table3.Fields[5] .AsString; 
temp[r,3] := Table3.Fields[6] .AsString; 
temp[r,4] := Table3.Fields[7] .AsString; 


info[r,0] := Table3.Fields[0] .AsString; 
info[r,i] := Table3.Fields[1i] .AsString; 
info[r,2}] := Table3.Fields[2] .AsString; 


Table3.Next(); 
end; 
Table3.close; 
end; 


{check for relationships and turn on boolean flags once a 
relationship has been established. Order of precedence: 
user selected All, exact variable match, child, sibling, 
parent, second level child, second level parent} 


with Query4 do 


begin 
for r := 0 to (N_T_R - 1) do 
begin 
for v := QO to 4 do 


begin 
{if user selects ALL we consider it a match} 
if (Var_Value[v] = ’ALL’) then 
begin 
Var_All_Bool[r,v] := True; 
end; 


{a match is assigned a score of 1.0} 
if (Var_Value[v] = temp[r,v]) then 
begin 
Match_Bool[r,v] := True; 
end; 


{check for child relationships} 
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if (Var_All_Bool([r,v] <> True) and 
(Match_Booll[r,v] <> True) then 
begin 
with Table5 do 
begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Search_Temp_3’ ; 
TableType := ttParadox; 
EmptyTable; 
end; 
Query4.SQL.clear; 
Query4.SQL.add (’SELECT * FROM Taxonomy’); 
Query4.SQL.add (’WHERE (’+C+’? = "’+Var_Valuel[v] 
+7" AND ?+P+’ = "?+tempigay|+ °")°>); 
BatchMove3.Execute; 
Query4.close; 
with Table5 do 
begin 
Table5.open; 
if Table5.RecordCount > O then 
begin 
child{r,vi] := Troe: 
end; 
Table5.close; 
end; 
end; 


{check for parent relationship} 
if (Var_All_Bool([r,v] <> True) and 
(Match _Boollr,v] <> True) and 
(child[r,v] <> True) then 
begin 
with TableS do 
begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Search_Temp_3?’ ; 
TableType := ttParadox; 
EmptyTable; 
end; 
Query4.SQL.clear; 
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Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 
Query4.SQL.add (’WHERE (’+C+’? = "’+temp[r,v]+’" AND ’ 
+P+’? = "’4+Var_Value[v]+ ’")’); 
BatchMove3.Execute; 
Query4.close; 
with Table5 do 
begin 
Table5. open; 
if Table5.RecordCount > O then 
begin 
parent(r,v] := True; 
end; 
Table5.close; 
end; 
end; 


{check for sibling relationship} 
if (Var_All_Booll[r,v] <> True) and 
(Match_Bool[r,v] <> True) and 
(chil@iiP vie<>"Irue) aaa 
(parent[r,v] <> True) then 
begin 
with Tabled do 
begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Search_Temp_3’ ; 
TableType := ttParadox; 
EmptyTable; 
end; 
Query4.SQL.clear; 
Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 
Query4.SQL.add (’WHERE (’+C+’ = "’4+Var_Value[v]+’")’); 
BatchMove3.Execute; 
Query4.close; 


with Tabled do 
begin 
Table5. open; 
Table5.First() ; 
P_Temp := Table5.Fields [0] .AsString; 
Table5.Close(); 
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{check to see if Parent is on top level 
-that is a meaningless relationship} 
if (P_Temp <> ’Problem Area’) and 
(P_Temp <> ’Functional Area’) and 
(P_Temp <> ’Solution Method’) and 
(P_Temp <> ’Industry Type’) and 
(P_Temp <> ’Organization Type’) then 
begin 
Query4.SQL.clear; 
Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 
Query4.SQL.add (’WHERE (’+C+’ = "’+temp(r,v] 
+? AND + Pa" ae +P Temp + ? or 
BatchMove3. Execute; 
Query4.close; 


Tabled. open; 
k := Table5.RecordCount ; 
Table5.Close(); 


if (k > 0) then 
begin 
sibling(r,v] := True; 
end; 
end; 
end; 
end; 


{check for second level child relationship} 
if (Var_All_Booll[r,v] <> True) and 
(Match_Bool[r,v] <> True) and 
(child[r,v] <> True) and 
(parent[r,v] <> True) and 
(sibling[r,v] <> True) then 
begin 
with Table6 do 
begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Tax_Temp’ ; 
TableType := ttParadox; 
EmptyTable; 


Lae 


end; 


Query4.SQL.clear; 

Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 

Query4.SQL.add (’WHERE (’+C+’? = "? 
+Var_Value[v]+’")’); 

BatchMove4.Execute; 

Query4.close; 


with Table6 do 
Table6. open; 
Table6.First() ; 
begin 
j := Table6.RecordCount ; 
for i := 0 tom@piade 
begin 
C_2_Temp := Table6.Fields[0] .AsString; 
if (C_2_Temp <> ’Problem Area’) and 
(C_2_Temp <> ’Functional Area’) and 
(C_2_Temp <> ’Solution Method’) and 
(C_2_Temp <> ’Industry Type’) and 
(C_2_Temp <> ’Organization Type’) then 


begin 
Query4.SQL. clear; 
Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 
Query4.SQL.add (’WHERE (’+P+’ = "?’+temp[r,v] 
+?" CAND 7+C+? = "7 +Co2miemp+ 7!) ) 
BatchMoved.Execute; 
Query4.close; 


with Table7 do 
begin 
Table/.open; 
k := Table?’ .RecordCount; 
Table7 .Close(): 


if (ae> 0) then 
begin 
Child_Sec_Bool[r,v] := True; 
end; 
end; 
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end; 
Table6.Next() ; 
end; 
end; 
Table6.Close() ; 
end; 


{check for second level parent relationship} 
if (Var_All_Booll[r,v] <> True) and 
(Match_Bool[r,v] <> True) and 
(child[r,v] <> True) and 
(parent[r,v] <> True) and 
(sibling[r,v] <> True) and 
(Child_Sec_Boolf{r,v] <> True) then 


begin 
with Table6 do 

begin 
Active := False; 
DatabaseName := ’DNET’; 
TableName := ’Tax_Temp’ ; 
TableType := ttParadox; 
EmptyTable; 

end; 


Query4.SQL.clear; 

Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 

Query4.SQL.add (’WHERE (’+P+’? = '" 
+Var_Value[v]+’")’); 

BatchMove4. Execute; 

Query4.close; 


with Table6 do 
Table6. open; 
Table6.First() ; 
begin 
j := Table6.RecordCount ; 


for i := 0 to jedo 

begin 
P_2_Temp := Table6.Fields[1] .AsString; 
Query4.SQL.clear; 
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Query4.SQL.add (’SELECT * FROM Taxonomy’) ; 

Query4.SQL.add (’WHERE (’+P+’ = "’+P_2_Temp+’" 
AND ?+C+? = “even ie) vee ee ; 

BatchMoved.Execute; 

Query4.close; 


with Table7 do 
begin 
Table7. open; 
k := Table7.RecordCount ; 
Table7 .Close(); 


if k > O then 
begin 
Parent_Sec_Booll[r,v] := True; 
end ; 
end; 
Table6.Next(); 
end; 
end; 
Table6.Close(); 
end; 
end; 


{evaluate booleans and set the R_V_S accordingly} 


for r := 0 to (N_T_R - 1) @o 
begin 
for v := 0 to 4 do 
begin 

{if user selects ALL we consider it a match} 

if (Var_All_Booll[r,v] = True) then 
begin 

Bev oS lmev) )-— 150 

end 


{a match is assigned a score of 1.0} 
else if (Match_Bool[r,v] = True) then 
begin 
R_V_S{r,v] := 120 
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end 


{query taxonomy.db for child relationship} 
else if (childf{r,v] = True) then 
begin 
R_V_S(r,v] := Deg_Value[v,0] 
end 


{query taxonomy.db for parent relationship} 
else if (parent(r,v] = True) then 
begin 
R_V_S[r,v] := Deg_Value[v, 1] 
end 


{query taxonomy.db for sibling relationship} 
else if (sibling[r,v] = True) then 
begin 
R_V_S(r,v] := Deg_Value[v, 2] 
end 


{query taxonomy.db for second level child relationship} 
else if (Child_Sec_Bool[r,v] = True) then 
begin 
R_V_S[r,v] := Deg_Valuel[v,0]*Deg_Value[v,0] 
end 


{query taxonomy.db for second level parent relationship} 
else if (Parent_Sec_Bool[r,v] = True) then 
begin 
R_V_S{r,v] := Deg_Valuel[v, 1] *Deg_Valuel[v, 1] 
end 


{if technology is listed as all we assign a score of 0.5} 
else if (temp[r,v] = ’ALL’ ) then 
begin 
R_V_S{[r,v] := 0.5 
end 


{no useful result yields a score of 0.0} 
else 
begin 
R_V_S[r,v] := 0.0; 
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{Calculate the Total Score for each record in Search_Temp_2.db} 


for r := 0 to (N_T_R - 1) do {should use RecordCount} 
begin 

T_S(r] := ((Weight [0])*(R_V_S[r,0])) 

((Weight (1])*(R_V_S[r,1])) 

( (Weight [2])*(R_V_S[r,2])) 

(Weight (3])*(R_V_S[r,3])) 

(Weight [4] )*(R_V_S[r,4])); 


+ + + + 


{standard header information} 

{all instances of the character & are for output parsing and 

have no effect on the search} 

send( ’ DecisionNet Search Engine Results’ + ’&’ ); 
send( ’? ’+’&’ ); 


{user selection information} 

send(’User Selections:’+ ’&’); 

send(’Problem Area = ’ + Var_Value[0]+ ’&’); 
send(’Functional Area = ’ + Var_Value[i]+ ’&’); 
send(’Solution Method = ’ + Var_Value[2]+ ’&’); 
send(’Industry Type = ’ + Var_Value[3]+ ’&’); 
send(’Organization Type = ’ + Var_Value[4]+ ’&’); 
send(’ ’+ ’&’); 


-+ 


+ 


send(’Problem Area Weight = ’ + FloatToStr(Weight[0]) + ’&’); 
send(’Functional Area Weight = ’ + FloatToStr(Weight[1]) + ’&’); 
send(’Solution Method Weight = ’ + FloatToStr(Weight[2]) + ’&’); 
send(’Industry Type Weight = ’ + FloatToStr(Weight([3]) + ’&’); 
send(’Organization Type Weight = ’ + FloatToStr(Weight[4]) + ’&’); 
send(’ °+ ?&): 


{sends T_S and R_V_S array values for individual technologies} 


for r= 0 to (Wale = 1) do 
begin 
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send(’TechID = ’ + infofr,i] +? TechName = ’ + info[r,2]+ ’&’); 
send(’ ’+ °&’); 
send(’Relevency Score = ’ + FloatToStr(T_S{r])+ ’&’): 
send(’Score for (Problem Area) = 
St Loa hootr (Rives tr, v] +5 7%); 
send(’Score for (Functional Area) = 
oe Floattootu(R_V.sir,v)])+ 2). 
send(’Score for (Solution Method) = 
meee LOatTootriR Voir, v))+ Mae 
send(’Score for (Industry Type) = 
+ FloatTostr(R_V_Sir,v])+ °see 
send(’Score for (Organization Type) = 
’ + FloatToStr(R_V_S[r,v])+ °&’); 
Senay’ ?+ ?&’); 
end; 


{standard footer information} 

send( ’This search engine was created by LT Chris Congnata’ + 227 )- 

send( ’for Professor Hemant Bhargava at the Naval Postgraduate 
School.’+ ’& ); 

send( ’Generated on ’ + webdate(now) + ’&’): 


CcloseStdout ; 
closeApp( application ); 
end; 
end; 
end. 
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APPENDIX P. TAXONOMY LEVEL 1 
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Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 
Problem 


Type 
Type 
Type 
Type 
Type 
Type 
Type 


Type 


Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
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ALL 

Algorithm 

Data Set 

Decision Support System 
Example 

Model Schema 

Modeling Language 

Solver 

ALL 

Asset Pricing 

Assignment 

Bin packing 

Capital budgeting 
Communications networks 
Corporate strategy 

Cost analysis 

Crew scheduling 

Depreciation 

Environment systems analysis 
Facilities/equipment planning 
Fire models 

Hierarchical production planning 
Inventory 

Investment 

Knapsack problem 

Job shop scheduling 
Layout/Location of equipment 
Learning/Training 

Lifecycle 

Location analysis 
Maintenance/Repair 

Manpower planning 

Material Handling 

Planning 

Production 

Quality Control 

Reliability of systems 

Risk assessment /management 
Safety 


Problem 
Problem 
Problem 
Problem 
Problem 


Area 
Area 
Area 
Area 
Area 


Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 
Functional 


Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 


Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 


Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
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Scheduling/sequencing 
Taxation 
Utility/Preferences 
Vehicle routing 
Yield management 
ALE 

Administration 
Engineering 

Finance 

Legal 

Logistics 
Maintenance 
Marketing 

Payroll 

Personnel 

Shopping 

Supply 

Testing 

Training 
Transportation 
Telecommunications 
ALL 

Aerospace/Space 
Accounting 
Agriculture 

Arts 
Business/Commerce 
Communications 
Construction 
Consumer 

Economics 

Education 

Emergency Services 
Energy 

Engineering 
Entertainment /Media 
Environment/Ecology 
Finance 

Government 
Health/Medicine 
International Trade 
Labor 


Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 
Industry 


Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 
Type 


Organization Type 
Organization Type 
Organization Type 
Organization Type 
Organization Type 
Organization Type 


solution 
solution 
Solution 
solution 
solution 
Solution 
solution 
solution 
solution 
solution 
solution 
solution 


Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 
Area 


Law 

Libraries 

Manufacturing 

Marketing 

Military 

Natural Resources 
Petro-Chemical 
Population 

Recreation and Sports 
Scientific Research 
Transportation 

ALL 

Military 

Government (non-military) 
Commercial 
Non-commercial/non-profit 
Personal/Individual 

ALL 
Simulation/stochastic modeling 
Statistics/probability 
Gaming 

Linear Programming 
Optimization 

Numerical Math 
Spreadsheet modeling 
Knowledge based 
Symbolic Math(calculus) 
Decision Analysis 

Other 
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Agriculture 
Agriculture 
Agriculture 
Agriculture 

Arts 

Arts 

Arts 
Business/Commerce 
Business/Commerce 
Business/Commerce 
Business/Commerce 
Business/Commerce 
Construction 
Construction 
Economics 

Economics 

Education 

Education 

Education 

Education 

Education 

Emergency Services 
Emergency Services 
Emergency Services 
Entertainment /Media 
Entertainment/Media 
Entertainment /Media 
Entertainment /Media 
Entertainment/Media 
Entertainment/Media 
Environment/Ecology 
Environment/Ecology 
Environment/Ecology 
Environment/Ecology 
Environment/Ecology 
Finance 

Finance 

Finance 

Finance 
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Crops 

Food Production 
Livestock 
Weather 

Fine Arts 
Music 

Theater 
Apparel 
General Retailing 
Mail-order 
Restaurant 
Wholesale 
Architecture 
Materials 
Macroeconomics 
Microeconomics 
K-12 
Undergraduate 
Graduate 
Career training 
Vocational 
Fire 

Police 
Hospitals 
Broadcasting 
Film 

Music 
Publishing 
Radio 
Television 

Air quality 
Forestry 
Pollution 
Recycling 
Water quality 
Banking 
Insurance 
Investment 
Mortgage 


Finance 
Finance 


Government 
Government 
Government 
Government 
Government 
Government 


Health/Medicine 
Health/Medicine 
Health/Medicine 


Libraries 


Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 
Manufacturing 


Military 
Military 
Military 
Military 
Military 
Military 
Military 


Scientific 
Scientific 
Scientific 
scientific 
Scientific 
Scientific 
Scientific 
Scientific 


Research 
Research 
Research 
Research 
Research 
Research 
Research 
Research 


Transportation 
Transportation 
Transportation 
Transportation 
Transportation 
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Personal 

Real Estate 
Elections 

Energy Policy 
Public Works 
Regulations 

Tax Policy 

Urban Systems 
Exercise 

Health care 
Nutrition 
Archives 
Aerospace 
Automotive 
Building materials 
Chemical 
Clothing/Textiles 
Forest/Paper products 
Furniture 

Metals 
Pharmaceuticals 
Plastics 

Avionics 

Command and Control 
Data processing 
Simulation 
Software tools 
Telecommunications 
Testing 
Chemistry 
Geography 
Engineering 
Mathematics 
Meteorology 
Oceanography 
Physics 
Statistics 
Airline 
Automobile 

Cargo 

Railroad 
Shipping 


Simulation/stochastic modeling Simulation 
Simulation/stochastic modeling Queuing 
Simulation/stochastic modeling Reliability 
Statistics/probability Approximation 


Statistics/probability Statistics,Probability 


Optimization Linear Algebra 
Optimization Optimization 
Numerical Math Arithmetic 


Numerical Math 
Numerical Math 


Number theory 
Elementary/special functions 


Numerical Math Interpolation 
Numerical Math Nonlinear equations 
Numerical Math Approximation 


Symbolic Math(calculus) 
Symbolic Math(calculus) 
Symbolic Math(calculus) 
Symbolic Math(calculus) 


Elementary/Special Functions 
Differentiation/integration 
Differential/integral equations 
Integral transforms 


Decision Analysis Decision Trees 
Decision Analysis Utility Theory 
Decision Analysis Influence Diagrams 
Decision Analysis AHP 

Decision Analysis Risk Analysis 


141 





APPENDIX R. TAXONOMY LEVEL 3 


This file has been formatted for display. Where line 

breaks appear, it is only to fit the text on this page. The 
actual data file has no blank lines and the child variable 
always starts at character position 39. 


Simulation 
Simulation 
Reliability 
Reliability 
Approximation 
Approximation 
Approximation 


Approximation 
Approximation 
Approximation 
Approximation 
Approximation 
Approximation 
Statistics,Probability 
Statistics, Probability 
Stavioules bo baol LILy 
Statistics,Probability 
Statistics,Probability 
Statistics, Probabasaty 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Statistics,Probability 
Stabisties, Probability 
Linear Algebra 

Linear Algebra 
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Discrete 

Continuous (Markov) 

Quality control 

Electrical network 

Least squares approximation 
Minimax approximation 

Least absolute value 
approximation 

Other approximations 
smoothing 

Service routines ,approximation 
Grid or knot generation 
Manipulation of basis functions 
Other 

Data Summarization 

Data manipulation 

Elementary statistical graphics 
Elementary data analysis 
Function evaluation 

Random number generation 
Analysis of variance 
Regression 

Categorical data analysis 

Time series analysis 
Correlation analysis 
Discriminant analysis 
Covariance structure models 
Cluster analysis 

Life testing,survival analysis 
Random number generation 
Multidimensional scaling 
Statistical data sets 

Systems of linear equations 
Determinants 


Linear Algebra 
Linear Algebra 


Linear Algebra 
Linear Algebra 
Linear Algebra 
Linear Algebra 
Optimization 
Optimization 
Optimization 
Optimization 
Arithmetic 
Arithmetic 
Arithmetic 
Arithmetic 
Arithmetic 
Arithmetic 
Arithmetic 
Elementary/special 
Elementary/special 
Elementary/special 
Elementary/special 


Elementary/special 


Elementary/special 
Elementary/special 
Elementary/special 
Elementary/special 
Elementary/special 


Elementary/special 
Elementary/special 


Elementary/special 
Elementary/special 
Elementary/special 
Elementary/special 
Elementary/special 
Elementary/special 
Interpolation 

Interpolation 


functions 
functions 
functions 
functions 


functions 


functions 
functions 
functions 
functions 
functions 


functions 
functions 


functions 
functions 
functions 
functions 
functions 
functions 
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Eigenvalues, eigenvectors" 
QR decomposition/Gram-Schmidt 
orthogonalization 

Singular value decomposition 
Update matrix decomposition 
Other matrix equations 
Generalized inverses 
Unconstrained 

Constrained 

Optimal Control 

service routines 

Integer 

Rational 

Real 

Complex 

Interval 

Change of representation 
Sequences 

Integer-valued functions 
Powers ,roots, reciprocals 
Polynomials 

Elementary transcendental 
functions 
Exponential/logarithmic 
integrals 

Gamma 

Error functions 

Legendre functions 

Bessel functions 

Confluent hypergeometric 
functions 

Coulomb wave functions 
Jacobian elliptic 
functions/theta 

Flliptical integrals 
Weierstrass elliptic functions 
Parabolic cylinder functions 
Mathieu functions 
Spheroidal wave functions 
Other special functions 
Univariate data 
Multivariate data 


Interpolation 
Nonlinear equations 
Nonlinear equations 
Nonlinear equations 
Approximation 
Approximation 
Approximation 


Approximation 

Approximation 

Approximation 

Approximation 

Approximation 

Approximation 

Approximation 
Elementary/special functions 
Elementary/special functions 
Elementary/special functions 
Differentiation, integration 
Differentiation, integration 
Differential/integral equations 
Differential/integral equations 
Differential/integral equations 
Integral transforms 


Integral transforms 
Integral transforms 
Integral transforms 
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service routines, interpolation 
Single equation 

system of equations 

Service routine 

Least squares approximation 
Minimax approximation 

Least absolute value 
approximation 

Other analytic approximations 
Smoothing 

Service routines, approximation 
Grid or Knot generation 
Manipulation of basis functions 
Other 

Nonlinear least squares 
Integer valued functions 
Powers ,roots,recipricals 
Polynomials 

Multidimensional integrals 
Service routines 

Ordinary differential equations 
Partial differential equations 
Integral equations 
Trigonometric/fast Fourier 
transforms 

Convolutions 

Laplace transforms 

Hilbert transforms 
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This file has been formatted for display. Where line 

breaks appear, it is only to fit the text on this page. The 
actual data file has no blank lines and the child variable 
always starts at character position 39. 


Least squares approximation 
Least squares approximation 
service routines for approx 
Data Summarization 

Data Summarization 

Data Summarization 

Data manipulation 

Data manipulation 

Data manipulation 

Data manipulation 

Data manipulation 

Elementary statistical graphics 
Elementary statistical graphics 
Elementary statistical graphics 
Elementary statistical graphics 
Elementary data analysis 
Elementary data analysis 
Elementary data analysis 
Elementary data analysis 
Function evaluation 

Function evaluation 

Random number generation 
Random number generation 
Random number generation 
Analysis of variance 

Analysis of variance 

Analysis of variance 

Analysis of variance 

Analysis of variance 

Analysis of variance 

Analysis of variance 
Regression 

Regression 

Regression 


Linear least squares 
Nonlinear least squares 
Evaluation of fitted functions 
One-dimensional data 
Two-dimensional data 
Multi-dimensional data 
Transform 

Tally 

subset 

Merge 

Construct new variables 
One-dimensional data 
Two-dimensional data 
Three-dimensional data 
Multi-dimensional data 
One-dimensional data 
Two-dimensional data 
Multi-dimensional data 
Multiple Multi-dimensional data 
Univariate 

Multivariate 

Univariate 

Multivariate 

Service routines 
One-way 

Two-way 

Three-way 

Multi-way 

Multivariate 

Generate experimental designs 
Service routines 

Simple linear 
Polynomial 

Multiple linear 


Regress 
Regress 
Regress 
Regress 
Regress 
Regress 
Categor 
Categor 
Categor 
Categor 
Time se 
Time se 
Cluster 
Cluster 
Cluster 
Cluster 
Systems 
Systems 
Systems 
Systems 
Systems 
Determi 
Determi 
Determi 
Determi 


10n 
10n 
10n 
10n 
ion 
10n 


ical data analysis 
ical data analysis 
ical data analysis 
ical data analysis 
ries analysis 
ries analysis 


analysis 
analysis 
analysis 
analysis 
of linear 
of linear 
of linear 
of linear 
of linear 
nants 
nants 
nants 
nants 


equations 
equations 
equations 
equations 
equations 


Figenvalues,eigenvectors 
Eigenvalues,eigenvectors 
Figenvalues,eigenvectors 
matrix decomposition 
matrix decomposition 
matrix decomposition 
matrix decomposition 
Generalized inverses 
Generalized inverses 
Generalized inverses 


Update 
Update 
Update 
Update 


Unconst 
Unconst 


rained 
rained 


Constrained 
Constrained 
Constrained 
Constrained 
Constrained 
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Polynomial in several variables 
Nonlinear 

Simultaneous 

Spline 

EDA 

Service routines 

2 by 2 tables 

Two-way tables 

Log-linear model 

EDA 

Univariate 

Two time series 

One-way 

Two-way 

Display 

Service routines 

Real nonsymmetric matrices 
Real symmetric matrices 
Complex non-Hermitian matrices 
Complex Hermitian matrices 
Associated operations 

Real nonsymmetric matrices 
Real symmetric matrices 
Complex non-Hermitian matrices 
Complex Hermitian matrices 
Ordinary eigenvalue problems 
Generalized eigenvalue problems 
Associated operations 

LU 

Cholesky 

QR 

Singular value 
Unconstrained 

Constrained 

Generalized inverses 
Univariate 

Multivariate 

Linear programming 
Transportation/assignment 
Integer programming 

Network 

Quadratic programming 


Constrained 

Constrained 

Constrained 

Constrained 

service routines 

service routines 

service routines 

service routines 

Service routines 

Real 

Real 

Real 

Complex 

Complex 

Complex 

Change of representation 
Change of representation 
Polynomials 

Polynomials 

Elementary transcendental functions 


Elementary transcendental functions 
Elementary transcendental functions 
Elementary transcendental functions 
Gamma 

Gamma 

Gamma 

Gamma 

Gamma 

Gamma 

Gamma 

EReor Tunct1 ons 


Panor funeceions 
Error functions 
Bessel functions 
Bessel functions 
Bessel functions 
Bessel functions 
Bessel functions 
Bessel functions 
Univariate data 
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Geometric programming 
Dynamic programming 

General nonlinear programming 
Problem input 

Problem scaling 

Check user-supplied derivatives 
Find feasible point 

Check for redundancy 

Other 

Standard precision 

Extended precision 

Extended range 

Standard precision 

Extended precision 

Extended range 

Base conversion 
Decomposition,construction 
Orthoginal 

Non-orthogonal 
Trigonometric,inverse 
trigonometric 

Exponential, logarithmic 
Hyperbolic, inverse hyperbolic 
Integrals 

Gamma/log gamma/reciprocal gamma 
Beta/log beta 

Psi functions 

Polygamma functions 
Incomplete gamma 

Incomplete beta 

Riemann zeta 
Functions/inverses/integral/ 
distributions 

Fresnel integrals 

Dawson’s integral 
J/Y 7H He2 

I/K 

Kelvin functions 

Airy and Scorer 
Stuve/Anger/Weber 

Integrals of Bessel 
Polynomial splines 


Univariate data 

Univariate data 

Multivariate data 

Multivariate data 

Service routines, interpolation 
Service routines, interpolation 
Service routines, interpolation 
Service routines, interpolation 
Single equation 

Single equation 

Least squares approximation 
Least squares approximation 
service routines,approximation 
Other 

Other 

Nonlinear least squares 
Nonlinear least squares 
Polynomials 

Polynomials 

Multidimensional integrals 
Multidimensional integrals 
Ordinary differential equations 
Ordinary differential equations 
Ordinary differential equations 
Partial differential equations 
Partial differential equations 


Polynomials 

Other functions 

Gridded 

Scattered 

Evaluate fitted functions 
Grid or knot generation 
Manipulation of basis functions 
Other 

Polynomial 

Nonpolynomial 

Linear least squares 
Nonlinear least squares 
Evaluation of fitted functions 
Unconstrained 
Constrained 
Unconstrained 
Constrained 

Orthogonal 

Non-orthogonal on grid 
hyper-rectangular regions 
n-dimensional quadrature 
Initial value 

Multipoint boundary value 
Service routines 

Initial boundary value 
Elliptic boundary value 


Trigonometric/fast Fourier transforms One-dimensional 
Trigonometric/fast Fourier transforms Multidimensional 
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